# 运算方法和运算器

- → 数据与文字的表示方法
- 一 定点加减运算
- 一 定点乘除运算
- 一 定点运算器的组成
- → 浮点运算方法和浮点运算器

### 真值和机器数



❷ 数的符号在计算机中的表示:

原码、反码、补码: 0表示正数,1表示负数

移码:

0表示负数,1表示正数

### 1.原码表示法 思考:原码表示绝对值最大(小)的正(负)数分别是什么?

若定点小数的真值为 $X = \pm 0.x_1x_2...x_n$ ,则原码表示的定义是:

$$[X]_{\mathbb{R}} = \begin{cases} X & 1 > X \ge 0 \\ 1 - X = 1 + |X| & 0 \ge X \ge -1 \end{cases}$$

例如,
$$x = +0.1001$$
,则[ $x$ ]<sub>原</sub>=0.1001  
 $x = -0.1001$ ,则[ $x$ ]<sub>原</sub>=1.1001

对于0,原码有"+0"、"-0"之分,故有两种形式:

$$[+0]_{\bar{\mathbb{R}}} = 0.000...0$$
  $[-0]_{\bar{\mathbb{R}}} = 1.000...0$ 

若定点整数的真值为 $X = \pm x_1 x_2 \dots x_n$ ,则原码表示的定义是:

$$[x]_{\mathbb{R}} = \begin{cases} X & 2^{n} > X \ge 0 \\ 2^{n} - X = 2^{n} + |X| & 0 \ge X > -2^{n} \end{cases}$$

采用原码表示法简单易懂,但它的缺点是运算复杂。

当两数相加时,如果是同号则数值相加;如果是异号,则要进行 减法。而在进行减法时还要比较绝对值的大小,然后大数减去小数,最 后还要给结果选择符号。

#### 2.反码表示法

所谓反码,就是二进制的各位数码0变为1,1变为0。在一些文献中,这种以2为基数的反码又称为1的补码。

对于正数
$$X = +0.x_1x_2...x_n$$
,则反码表示为:  $[x]_{\mathbb{Z}} = 0.x_1x_2...x_n$  对于负数 $X = -0.x_1x_2...x_n$ ,则反码表示为:  $[x]_{\mathbb{Z}} = 1.\overline{x_1}\overline{x_2}...\overline{x_n}$  例如, $x = +0.1001$ ,则 $[x]_{\mathbb{Z}} = 0.1001$   $x = -0.1001$ ,则 $[x]_{\mathbb{Z}} = 1.0110$ 

若定点小数的真值为 $X = \pm 0.x_1x_2...x_n$ ,则反码表示的定义是:

$$[x]_{\mathbb{Z}} = \begin{cases} X & 1 > X \ge 0 \\ (2-2^{-n}) + X & 0 \ge X \ge -1 \end{cases}$$

对于0,有[+0]<sub>反</sub>和[-0]<sub>反</sub>之分:

$$[+0]_{\text{p}} = 0.000...0$$
  $[-0]_{\text{p}} = 1.111...1$ 

若定点整数的真值为 $X = \pm x_1 x_2 \dots x_n$ ,则反码表示的定义是:

$$[x]_{\mathbb{Z}} = \begin{cases} X & 2^{n} > X \ge 0 \\ (2^{n+1}-1) + X & 0 \ge X \ge -2^{n} \end{cases}$$

#### 思考: 补码表示绝对值最大(小)的正(负)数分别是什么?

若定点小数的真值为 $X = \pm 0.x_1x_2...x_n$ ,则补码表示的定义是:

$$[x]_{\stackrel{}{\uparrow}} = \begin{cases} x & 1 > x \ge 0 \\ 2 + x = 2 - |x| & 0 \ge x \ge -1 \end{cases}$$
 (mod 2) 例如, $x = +0.1001$ ,则[ $x$ ] $_{\stackrel{}{\uparrow}} = 0.1001$   $x = -0.1001$ ,则[ $x$ ] $_{\stackrel{}{\uparrow}} = 1.0111$  [ $+0$ ] $_{\stackrel{}{\uparrow}} = [-0]_{\stackrel{}{\uparrow}} = 0.000...0$  [ $-1$ ] $_{\stackrel{}{\uparrow}} = 1.000...0$ 

若定点整数的真值为 $X = \pm x_1 x_2 \dots x_n$ ,则补码表示的定义是:

$$[X]_{\nmid h} = \begin{cases} X & 2^{n} > X \ge 0 \\ 2^{n+1} + X = 2^{n+1} - |X| & 0 \ge X \ge -2^n \end{cases} \pmod{2^{n+1}}$$

对于负数,补码等于反码的最低位加1:

$$[-2^n]_{n} = 1000...0$$

$$[x]_{\stackrel{}{\wedge}} = [x]_{\stackrel{}{\vee}} + 2^{-n} \qquad x \text{ 为小数}$$
$$[x]_{\stackrel{}{\wedge}} = [x]_{\stackrel{}{\vee}} + 1 \qquad x \text{ 为整数}$$

#### 4.移码表示法

若定点整数的真值为 $X = \pm x_1 x_2 ... x_n$ ,则移码表示的定义是:

$$[x]_{8} = 2^{n} + x$$
  $2^{n} > x \ge -2^{n}$ 

例如,
$$x = +1001$$
,则[ $x$ ]<sub>移</sub>=11001  
 $x = -1001$ ,则[ $x$ ]<sub>移</sub>=00111

四种机器码的比较(以n+1位定点整数为例):

- 1. 原码、反码和补码的符号位为0正1负,移码为1正0负;
- 2. 原码和反码的表示范围为  $2^{n} > x > -2^{n}$ , 0的原码和反码都有两个;补码和移码的表示范围为 $2^{n} > x \ge -2^{n}$ , 0的补码和移码都只有一个;
- 3. 正数的原码、反码和补码相同,负数则不同;
- 4. 移码等于补码的符号位取反;移码的大小关系与真值的 大小关系相同。

| 真值 | 原码                 | 反码                 | 补码                 | 移码                 |
|----|--------------------|--------------------|--------------------|--------------------|
| +7 | 0111               | 0111               | 0111               | 1111               |
| +6 | <mark>0</mark> 110 | 0110               | <mark>0</mark> 110 | <mark>1</mark> 110 |
| +5 | <mark>0</mark> 101 | <mark>0</mark> 101 | <mark>0</mark> 101 | <mark>1</mark> 101 |
| +4 | 0100               | 0100               | 0100               | <mark>1</mark> 100 |
| +3 | 0011               | 0011               | 0011               | <b>1</b> 011       |
| +2 | 0010               | 0010               | 0010               | <b>1</b> 010       |
| +1 | 0001               | 0001               | 0001               | <b>1</b> 001       |
| +0 | 0000               | 0000               | 0000               | 1000               |
| -0 | 1000               | 1111               | _                  | _                  |
| -1 | 1001               | <b>1</b> 110       | 1111               | <mark>0</mark> 111 |
| -2 | <b>1</b> 010       | <b>1</b> 101       | <b>1</b> 110       | <b>0</b> 110       |
| -3 | 1011               | <b>1</b> 100       | <b>1</b> 101       | <mark>0</mark> 101 |
| -4 | <b>1</b> 100       | <b>1</b> 011       | <b>1</b> 100       | <b>0</b> 100       |
| -5 | <b>1</b> 101       | <b>1</b> 010       | <b>1</b> 011       | 0011               |
| -6 | <b>1</b> 110       | 1001               | <b>1</b> 010       | 0010               |
| -7 | <b>1111</b>        | 1000               | 1001               | 0001               |
| -8 | _                  | _                  | 1000               | 0000               |

### 数据格式

计算机中常用的数据表示格式有两种,一是定点格式,二是浮点格式。 定点格式容许的数值范围有限,但要求的处理硬件比较简单,浮点格式容许 的数值范围很大,但要求的处理硬件比较复杂。

#### 1.定点数的表示方法

定点数是指小数点的位置固定不变。小数点的位置是事先约定的,不需要占用一个二进制位来表示。通常将数据表示成纯小数或纯整数。

#### 定点小数

小数点位于符号位和最高有效位之间。



采用原码表示时,所能表示的数的范围是:  $0 \le |X| \le 1 - 2^{-n}$ 。

#### 定点整数

小数点位于最高有效位之后。



采用原码表示时,所能表示的数的范围是:  $0 \le |X| \le 2^n - 1$ 。

#### 2.浮点数的表示方法

一个R进制的数N可以写成  $N = M \times R^{E}$ 

其中M为尾数,E为指数,R为基数。在计算机中通常取R为2、8或16。

在机器中表示一个浮点数时,一要给出尾数,用定点小数的原码或补码表示;二要给出指数,用整数的补码或移码表示,称为阶码。

$$0.0 \times 10^{99}$$
 $0.0 \times 10^{-9}$ 
 $0.0 \times 10^{-9}$ 
 $-9.9 \times 10^{-100}$ 
 $7.8 \times 10^{-100}$ 



为了使浮点数的表示形式唯一,当尾数M不为0时,若尾数用原码表示,规定  $\frac{1}{2} \le |M| < 1$ ,即尾数的二进制形式为 $0.1 \times \times ... \times$ 或 $1.1 \times \times ... \times$ ;若尾数用补码表示,规定  $\frac{1}{2} \le M < 1$ 或 $-1 \le M < -\frac{1}{2}$ ,即尾数的二进制形式为 $0.1 \times \times ... \times$ 或 $1.0 \times \times ... \times$ 。这称为浮点数的规格化表示。 $M = -\frac{1}{2}$ 对于原码表示是规格化的,对于补码表示则不是。 P22的规格化

当一个浮点数的尾数M=0,不管阶码取何值,或者阶码比它能表示的最小值还小时,不管尾数取何值,都把该浮点当零看待,称为机器零。此时要求把浮点数的阶码和尾数都清为零,保证零这个数表示的唯一性。

**浮点数的表示范围**:设阶码和尾数都用补码表示,阶码共k+1位(含一位阶符),尾数共n+1位(含一位数符)。浮点数的表示范围如下:

|            | 阶码                   | 尾数             | 真值                                |
|------------|----------------------|----------------|-----------------------------------|
| 最大正数       | <mark>0</mark> , 111 | <b>0</b> . 111 | $(1-2^{-n})\times 2^{2^k-1}$      |
| 绝对值最大负数    | <mark>0</mark> , 111 | 1.000          | $(-1)\times 2^{2^k-1}$            |
| 最小正数       | 1,000                | <b>0</b> . 001 | $(2^{-n})\times 2^{-2^k}$         |
| 规格化最小正数    | 1,000                | 0. 100         | $(2^{-1})\times 2^{-2^k}$         |
| 绝对值最小负数    | 1,000                | 1. 111         | $(-2^{-n})\times 2^{-2^k}$        |
| 规格化绝对值最小负数 | 1,000                | 1. 011         | $-(2^{-1}+2^{-n})\times 2^{-2^k}$ |

#### IEEE 754 标准

IEEE 754是目前广泛采用的浮点数编码格式,分为单精度、双精度表示。

单精度: 32位浮点数:



双精度: 64位浮点数:



32位浮点数中,S是浮点数的符号位,占1位,安排在最高位,0正1负。符号位后面是阶码E,占8位。E的计算方法是将浮点数的指数真值加上一个固定的偏移值127(这也叫移码)。E的取值范围是1~254,对应的指数真值为-126~+127。E取255表示"无穷大",E取0表示机器零。M是尾数,占23位,放在最低位,用原码表示。尾数的真值为1.M,即在M前面有一个隐藏的1。这相当于将尾数规格化到1和2之间,而将整数部分的1隐藏不表示。

一个32位浮点数X的真值可表示为:

12 
$$X = (-1)^{S} \times (1.M) \times 2^{E-127}$$

64位浮点数中,阶码E占11位,计算方法是将浮点数的指数真值加上一个固定的偏移值1023。E的取值范围是1~2046,对应的指数真值为一1022~+1023。E取2047表示"无穷大",E取0表示机器零。尾数M占52位,有一个隐藏位1。

一个64位浮点数X的真值可表示为:

$$X = (-1)^{S} \times (1.M) \times 2^{E-1023}$$

#### IEEE 754标准中的一些特殊值(以32位为例):

|       | 符号  | 阶码  | 尾数       | 值   |
|-------|-----|-----|----------|-----|
| 正零:   | 0   | 0   | 0        | +0  |
| 负零:   | 1   | 0   | 0        | -0  |
| 正无穷大: | 0   | 255 | 0        | +∞  |
| 负无穷大: | 1   | 255 | 0        | -∞  |
| 非数:   | 0或1 | 255 | $\neq 0$ | NaN |

#### 注意:

本书中提及的规格化有两种,移码也有两种。

IEEE754标准指的移码以及规格化与浮点数表示不同。

|           | 移 码                                   | 规 格 化                              |
|-----------|---------------------------------------|------------------------------------|
| IEEE754标准 | 真值加 <b>127</b>                        | 尾数的真值为1.M<br>并将整数部分的1隐藏不表          |
| 浮点数       | 真值加 <b>2</b> <sup>n</sup><br>与补码区别符号位 | 原码: 1.1××或0.1××<br>补码: 1.0××或0.1×× |

## IEEE 754 标准

- 将-27/64用IEEE754表示
- -27/64 = -0.011011
- 规格化: (必须是1.M的形式) 0.011011 = 1.1011 × 2<sup>-2</sup>
- 阶码为 -2 E=e+127=01111101
- 1 01111101 1011000.....000

符号 阶码8位

尾数23位

### 用 IEEE754的单精度表示方法表示-0.75D

解: 
$$-0.75=2^{\circ}\times(-0.11000)$$
  
= $2^{-1}\times(-1.1000)$ 

IEEE754标准:

1 01111110 100..... 000000

**†** 

符号 阶码8位

尾数23位

• 设某机器用32位表示一个实数,阶码部分8位(含1位) 阶符),用定点整数补码表示;尾数部分24位(含数 符1位),用规格化定点小数补码表示,基数为2。



- 1) 求X=256.5的浮点表示格式(16进制格式表示)
- 2) 求Y=-256.5的浮点表示格式(16进制格式表示)
- 将十进制数178.125表示成IEEE754单精度浮点数
- 将下面IEEE754的单精度浮点数表示成十进制真值是 多少?
  - 1011,1111,0101,1000,0000,0000,0000,0000

 $X=(256.5)_{10}=+(100000000.1)_2=+(0.1000000001\times 2^{+9})_2$ 

8位阶码为: (+9)\*=0000 1001

24位尾数为: (+0.10 0000 0001)\*\*

=0.100 0000 0010 0000 0000 0000

所求256.5的浮点表示格式为:

0000 1001 0100 0000 0010 0000 0000 0000

用16进制表示此结果则为: (09402000)16

```
Y=-(256.5)_{10}=-(100000000.1)_2
 =-0.100000001 \times 2^{+9}
  8位阶码为: (+9)补=0000 1001
  24位尾数为: (-0.10 0000 0001)补
 =1.011 1111 1110 0000 0000 0000
  所求-256.5的浮点表示格式为:
 0000 1001 1011 1111 1110 0000 0000
```

用16进制表示此结果则为: (09BFE000)<sub>16</sub>

0000

178.125 = 10110010.001B=  $1.0110010001x2^7$ 

指数E=7+127=134=10000110B

- 127是单精度浮点数应加的指数偏移量,其完整的浮点数形式为:
  - 0 10000110 011 0010 0010 0000 0000 0000
  - = 43322000H

1011,1111,0101,1000,0000,0000,0000,0000

数符:S=(-1) <sup>1</sup>=-1 (负号)

阶码: E=(01111110)<sub>2</sub>-127=126-127= -1

尾数: D=(1.1011)<sub>2</sub>

 $X = -1.1011x2^{-1} = -(0.11011)_2 = -0.84375$ 

注意:

计算的每一个步骤都需认真仔细,不要出错。

考试时候不允许使用计算器

#### 3.十进制数串的表示方法

十进制数串在计算机内主要有两种表示形式:

#### 字符串形式

一个字节存放一位十进制数或符号的ASCII码。这种表示方法主要用在 非数值计算领域。

#### 压缩的十进制数串形式

每个字节存放两个十进制数位,每个数位占4位二进制数。通常存放该十进制数位的8421码。符号位也占半个字节,并存放在最低数值位之后,通常用1100表示正号,1101表示负号。在这种表示中,规定数字的个数加符号位之和必须为偶数;当和为奇数时,应在最高数值位之前补0。

+123: 1 2 3 C -12: 0 1 2 D

### 字符和字符串

目前国际上普遍采用的字符系统是用7位二进制信息表示的美国国家信息交换标准码,简称ASCII码。

ASCII码是128个字符组成的字符集。其中编码值0~31和127为控制字符,用于通信中的通信控制或对计算机设备的功能控制。另外95个编码对应于95个可以从计算机终端输入并且可以显示和打印的有形字符。

一个字符在计算机中占据一个字节,用8位二进制数表示。其中最高位b<sub>7</sub>在传输过程中可用作奇偶校验位,存储字符时则取0。

ASCII码编码中有如下两个规律:

- (1) 字符0~9这10个数字符的高3位编码为011, 低4位为0000~1001。 当去掉高3位的值时, 低4位正好是二进制形式的0~9。
- (2) 英文字母的编码值满足正常的字母排序关系,且大小写英文字母编码的对应关系相当简便,差别仅表现在b<sub>5</sub>一位的值为0或1,

## ASCII码表

| b6 b5 b4    | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
|-------------|-----|-----|-----|-----|-----|-----|-----|-----|
| b3 b2 b1 b0 |     |     |     |     |     |     |     |     |
| 0000        | NUL | DLE | SP  | 0   | @   | Р   | •   | р   |
| 0001        | SOH | DC1 | !   | 1   | Α   | Q   | а   | q   |
| 0010        | STX | DC2 | "   | 2   | В   | R   | b   | r   |
| 0011        | ETX | DC3 | #   | 3   | С   | S   | С   | S   |
| 0100        | EOT | DC4 | \$  | 4   | D   | Т   | d   | t   |
| 0101        | ENQ | NAK | %   | 5   | Ε   | U   | е   | u   |
| 0110        | ACK | SYN | &   | 6   | F   | V   | f   | V   |
| 0111        | BEL | ETB | •   | 7   | G   | W   | g   | W   |
| 1000        | BS  | CAN | (   | 8   | Н   | X   | h   | X   |
| 1001        | HT  | EM  | )   | 9   | - 1 | Υ   | i   | У   |
| 1010        | LF  | SUB | *   | :   | J   | Z   | j   | Z   |
| 1011        | VT  | ESC | +   | ;   | K   | [   | k   | {   |
| 1100        | FF  | FS  | ,   | <   | L   | ١   | I   | 1   |
| 1101        | CR  | GS  | -   | =   | M   | ]   | m   | }   |
| 1110        | SO  | RS  |     | >   | N   | ^   | n   | ~   |
| 1111        | SI  | US  | /   | ?   | 0   |     | 0   | DEL |
|             |     |     |     |     |     | _   |     |     |

字符串是指连续的一串字符,在主存中通常占用连续的多个字节,每个字节存放一个字符。当主存中一个字由若干个字节构成时,在同一个主存字内,字符串中各个字符既可从低字节向高字节依次存放,也可按从高字节到低字节顺序存放。

#### 例:对于字符串 IF A>B THEN READ(C)

假定计算机字长32位,每个存储单元分成4个字节,每个字节存放一个字符,空格在主存中也占用一个字节位置。有以下两种存放方法:

| I | F | 空格 | A  |
|---|---|----|----|
| > | В | 空格 | T  |
| Н | E | N  | 空格 |
| R | E | A  | D  |
| ( | C | )  | 空格 |

| A  | 空格 | F | I |
|----|----|---|---|
| Т  | 空格 | В | > |
| 空格 | N  | E | Н |
| D  | A  | E | R |
| 空格 | )  | С | ( |

### 汉字的表示

#### 1.汉字的输入编码

汉字的输入编码主要有三种: 数字编码、拼音码和字型码。

数字编码常用的是区位码。根据GB 2321—80方案,汉字基本字符集共6763个,还有西文字母、数字、图形符号等682个,共计7445个。所有的国标汉字与符号组成一个94×94的矩阵。其中的每一行称为一个"区",区号为01~94;每一列称为一个"位",位号也为01~94。01~09区为图形符号,16~87区为汉字。一个汉字所在的区号和位号简单地组合在一起就构成了该汉字的区位码。区码和位码各两位十进制数字,因此输入一个汉字需按键四次。例如"啊"位于16区01位,区位码为1601。

如果区号和位号都用16进制表示,并且都从21H开始编号(ASCII码中第一个可显示的字符就是21H),得到的编码称为汉字的国标码。例如"啊"的国标码为3021 H。国标码和区位码的关系为:

国标码=区位码(16进制) + 2020 H

#### 2.汉字的内码

汉字内码是用于汉字信息的存储、交换、检索等操作的机内代码,一般采用两个字节表示。为了和ASCII码相互区别,汉字内码的两个字节的最高位均规定为"1",即将国标码每个字节的最高位变为1:

内码=国标码+8080 H=区位码(16进制)+A0A0 H 例如"啊"的内码为B0A1 H。

#### 3.汉字的字模码

构造汉字字型有两种方法,一是用向量法,一是用点阵法。目前普遍使用的汉字字型码是用点阵方式表示的。如一个汉字用16×16点阵表示,需要32个字节。



### 校验码

对于一种编码,任意两个合法码之间不同位的最小个数称为码距。例如用4位二进制码表示16个状态,则码距为1,这种编码没有检错能力。合理增大码距,可以提高发现错误的能力,但表示一定数量的合法码所需的二进制位数变多,增大了数据存储和传输的开销。

计算机内常遇到的错误有两大类:随机错误和突发错误。前者是孤立出现的一个错误,后者是连续产生的一批错误。本节只讨论前者。

#### 1. 奇偶校验码

由数据位和一位校验位组成。对于奇校验,数据位和校验位中1的个数为奇数个;对于偶校验,数据位和校验位中1的个数为偶数个。

若数据位为 $D_{n-1}...D_1D_0$ ,校验位为P,则:

对于奇校验:  $P = \overline{D_{n-1} \oplus ... \oplus D_1 \oplus D_0}$ 

对于偶校验:  $P = D_{n-1} \oplus ... \oplus D_1 \oplus D_0$ 

奇偶校验码的码距为2,具有发现一位错误的能力。

#### 2.海明校验码

海明码也是以奇偶校验为基础的,但校验位是一组而不是一位,它可以检测和定位一位错误。其原理是在*k*个数据位中加入*r*个校验位,*r*个校验位有2<sup>r</sup>个编码,用其中一个表示"没有错误",其余2<sup>r</sup>一1个编码指出错误出现在哪一位(可能是数据位,也可能是校验位),因此*r*应满足:

$$2^r-1 \ge k+r$$

例如r=4则k最大为11。

设4个校验位为 $P_1 \sim P_4$ ,11个数据位为 $D_0 \sim D_{10}$ ,形成海明码 $H_1 \sim H_{15}$ 。每个校验位 $P_i$ 被分配在海明码的第 $2^{i-1}$ 的位置上,其余位置为数据位,并按照从低位到高位的顺序排列。即

 $H_1$   $H_2$   $H_3$   $H_4$   $H_5$   $H_6$   $H_7$   $H_8$   $H_9$   $H_{10}$   $H_{11}$   $H_{12}$   $H_{13}$   $H_{14}$   $H_{15}$   $P_1$   $P_2$   $D_0$   $P_3$   $D_1$   $D_2$   $D_3$   $P_4$   $D_4$   $D_5$   $D_6$   $D_7$   $D_8$   $D_9$   $D_{10}$  每个数据位通过若干个校验位进行校验。例如 $D_8$ 是海明码的第13位 $H_{13}$ ,13=1+4+8,因此 $D_8$ 通过第1位 $P_1$ 、第4位 $P_3$ 、第8位 $P_4$ 进行校验。

#### 海明码的分组

| 海明码                            | 校验位位置      | 校验位                                           |
|--------------------------------|------------|-----------------------------------------------|
| $H_1=P_1$                      | 1          | <i>P</i> <sub>1</sub>                         |
| $H_2=P_2$                      | 2          | P <sub>2</sub>                                |
| $H_3=D_0$                      | 1, 2       | $P_1, P_2$                                    |
| $H_4=P_3$                      | 4          | <b>P</b> <sub>3</sub>                         |
| $H_5=D_1$                      | 1, 4       | $P_1, P_3$                                    |
| $H_6=D_2$                      | 2, 4       | $P_2$ , $P_3$                                 |
| $H_7=D_3$                      | 1, 2, 4    | $P_1, P_2, P_3$                               |
| H <sub>8</sub> =P <sub>4</sub> | 8          | P <sub>4</sub>                                |
| $H_9=D_4$                      | 1, 8       | <b>P</b> <sub>1</sub> , <b>P</b> <sub>4</sub> |
| $H_{10}=D_5$                   | 2, 8       | $P_2$ , $P_4$                                 |
| $H_{11}=D_6$                   | 1, 2, 8    | $P_1, P_2, P_4$                               |
| $H_{12}=D_7$                   | 4, 8       | $P_3$ , $P_4$                                 |
| $H_{13}=D_8$                   | 1, 4, 8    | $P_1, P_3, P_4$                               |
| $H_{14} = D_9$                 | 2, 4, 8    | $P_2, P_3, P_4$                               |
| $H_{15}=D_{10}$                | 1, 2, 4, 8 | $P_1, P_2, P_3, P_4$                          |
|                                |            |                                               |

从表中可以找出每个校验位分别校验那些码位,例如 $P_1$ 校验 $D_0$ ,

 $D_1$ ,  $D_3$ ,  $D_4$ ,  $D_6$ ,  $D_8$ 、  $D_{10}$ 和它自己。若采用偶校验,每个校验位就是它所校验的数据位的异或:

$$P_1 = D_0 \oplus D_1 \oplus D_3 \oplus D_4 \oplus D_6 \oplus D_8 \oplus D_{10}$$

$$P_2 = D_0 \oplus D_2 \oplus D_3 \oplus D_5 \oplus D_6 \oplus D_9 \oplus D_{10}$$

$$P_3 = D_1 \oplus D_2 \oplus D_3 \oplus D_7 \oplus D_8 \oplus D_9 \oplus D_{10}$$

$$P_4 = D_4 \oplus D_5 \oplus D_6 \oplus D_7 \oplus D_8 \oplus D_9 \oplus D_{10}$$

一 海明码传到接收方后,将校验 - 位与它校验的数据位异或:

$$-G_1=P_1\oplus D_0\oplus D_1\oplus D_3\oplus ...\oplus D_8\oplus D_{10}$$

$$-G_2=P_2\oplus D_0\oplus D_2\oplus D_3\oplus ...\oplus D_9\oplus D_{10}$$

$$-G_3=P_3\oplus D_1\oplus D_2\oplus D_3\oplus \ldots \oplus D_9\oplus D_{10}$$

$$- G_4 = P_4 \oplus D_4 \oplus D_5 \oplus D_6 \oplus \ldots \oplus D_9 \oplus D_{10}$$

#### 3.循环冗余校验码

在计算机网络、同步通信以及磁介质存储器中广泛使用循环冗余校验码,简称CRC码。CRC码是在k位数据位之后拼接r位校验位,形成n=k+r位编码。编码中用到模2运算。

模2运算以按位模2相加为基础,运算时不考虑进位和借位。

(1) 模2加减:可以异或运算实现,模2加与模2减结果相同。

$$0\pm0=0$$
,  $0\pm1=1$ ,  $1\pm0=1$ ,  $1\pm1=0$ .

(2) 模2乘:按模2加求部分积之和,不考虑进位。

|   | 1 | 0 | 1 | 1 |
|---|---|---|---|---|
| × |   |   | 1 | 1 |
|   | 1 | 0 | 1 | 1 |
| 1 | 0 | 1 | 1 |   |
| 1 | 1 | 1 | 0 | 1 |

(3)模2除:按模2减求余数。上商的原则是余数首位为1时商取1,余数首位为0时商取0,余数位数小于除数位数时该余数就是最终的余数。

#### 编码方法:

(1) 待编码的k位数据 $C_{k-1}C_{k-2}...C_1C_0$ 可表达为一个k-1阶多项式:

$$M(x) = C_{k-1}x^{k-1} + C_{k-2}x^{k-2} + ...C_1x + C_0$$

- (2) 将k个数据位左移r位,得到n=k+r位代码,对应的多项式为M(x) x r:  $C_{k-1}C_{k-2}...C_1C_0$  00...0
- (3) 用 $M(x)x^r$ 除以(模2除)某一个(r+1)位的多项式G(x)(称为生成多项式),得到商Q(x)和r位余数R(x):

$$M(x) x^r = Q(x) G(x) + R(x)$$

用R(x)代替M(x) x r 右边的r 个0 ,得到M(x) x r + R(x)就是所要的CRC编码。 校验原理:

因为M(x) x r + R(x) = Q(x) G(x) (模2加和模2减结果相同),准确传输的CRC码一定能被生成多项式G(x)整除。若余数不为0则表示传输出错,不同的余数表示不同的位出错。因此CRC码有纠正一位错误的能力。

#### 生成多项式:

有三种生成多项式具有极高的检错率,已经成为标准。它们是:

**CRC-12:** 
$$G(x) = x^{12} + x^{11} + x^3 + x^2 + x + 1$$

**CRC-16:** 
$$G(x) = x^{16} + x^{15} + x^2 + 1$$

**CRC-CCITT:** 
$$G(x) = x^{16} + x^{12} + x^5 + 1$$

#### 编码举例:

数据为1101,生成多项式为1011,求CRC编码。

将数据左移3位,得到1101000,再除以生成多项式1011,余数为001:

 $1101000 = 1111 \times 1011 + 001$ 

于是CRC编码为1101001。

接收方得到CRC码后,除以生成多项式1011,余数为0表示传输正确。 余数不为0表示某一位出错。例如余数为101表示最高位出错:

 $0101001 = 0100 \times 1011 + 101$ 

余数与出错的位之间有固定的对应关系。

#### CRC码的特点:

- (1) CRC码循环右移一位或循环左移一位,得到的新码仍是CRC码,并且校验位仍然在最右边的r位;
  - (2) 两个CRC码按位异或,得到的新码仍是CRC码。

#### 作业

- 1、P60-61 3 4
- 2、参照例2.7 以定点小数为例,用数轴形式说明 n+1位(含一位数符)小数原码,补码,反码表示的范围

## 上讲复习

- 数的原码、补码、反码、移码的表示方法,注意边界情况 (0的表示,表示范围,-2<sup>n</sup>以及-1)
- 浮点数的表示方法: 尾数用定点小数的原码或补码表示; 指数用整数的补码或移码表示。数符、阶符分别表示什么 含义? 正、负、绝对值大于1 若用补码表示,阶码尾数各有k+1位 规格化最小正数是: 1,00…0 0.10…0 (2<sup>-1</sup>)×2<sup>-2<sup>k</sup></sup>
- 数的规格化表示方法
- IEEE754表示方法 尾数用原码表示,规格化为1.M的形式,表示时隐藏1 阶码为真值加127

# 牛刀小试

- 设某机器用32位表示一个实数,阶码部分8位 (含1位阶符),用定点整数补码表示;尾数部分 24位(含数符1位),用规格化定点小数补码表 示,基数为2。求X=256.5的浮点表示格式 256.5=+(100000000.1)B
- 将十进制数178.125表示成IEEE754单精度浮点数 178.125=10110010.001B

## 所求256.5的浮点表示格式为:

0000 1001 0100 0000 0010 0000 0000 0000

178.125=10110010.001B

 $=1.0110010001x2^{7}$ 

指数E=7+127=134=10000110B

127是单精度浮点数应加的指数偏移量,其完整的浮点数形式为:

0 10000110 011 0010 0010 0000 0000 0000

### 补码加法

计算机内部的数大部分都是以补码表示

解:由  $[x]_{\uparrow}$ = 11111011 可知 x = -5由  $[y]_{\uparrow}$ = 00000011 可知 y = 3

$$[x+y]_{3} = 11111110$$

## 补码加法

用补码表示定点数,加减运算可以统一成加法运算。运算器中只需要一个加法器就可以了,不需要减法器。

补码加法的公式为:

$$[x]_{*}+[y]_{*}=[x+y]_{*}\pmod{2}$$

证明:设x和y均为定点小数,且运算结果没有溢出。即

$$|x| < 1, |y| < 1, |x+y| < 1$$

(1) x > 0, y > 0,则x+y > 0。正数的补码和原码是一样的,可得:

$$[x]_{*}+[y]_{*}=x+y=[x+y]_{*}$$
 (mod 2)

(2) x > 0, y < 0,  $x+y \ge 0$ 或x+y < 0。

$$[x]_{\uparrow h} = x,$$
  $[y]_{\uparrow h} = 2+y$   
 $[x]_{\uparrow h} + [y]_{\uparrow h} = x+2+y=2+(x+y)$ 

当x+y≥0时,2+(x+y)≥2,对于模2来说,2被丢掉,于是

$$[x]_{k}+[y]_{k}=x+y=[x+y]_{k}$$
 (mod 2)

当x+y < 0时, 2 + (x+y) < 2, 于是

$$[x]_{k}+[y]_{k}=2+(x+y)=[x+y]_{k}$$
 (mod 2)

(3) x < 0, y > 0.

这种情况和第2种情况证明方法相同。

$$[x]_{\dot{\uparrow}}=2+x$$
,  $[y]_{\dot{\uparrow}}=2+y$   $[x]_{\dot{\uparrow}}+[y]_{\dot{\uparrow}}=2+x+2+y=2+(2+x+y)$   $(2+x+y)$  小于2而大于1的数,第一个2作为进位被舍弃。于是  $[x]_{\dot{\uparrow}}+[y]_{\dot{\uparrow}}=2+(x+y)=[x+y]_{\dot{\uparrow}}$  (mod 2)

至此我们证明了在模2意义下,两数的补码之和等于这两个数之和的补码。这个结论也适用于定点整数。



解二:

$$[x+y]_{k}=[x]_{k}+[y]_{k}=11111011+00000011=11111110$$

### 补码减法

数用补码表示时,减法运算可转化为加法运算。公式为:

$$[x-y]_{\stackrel{*}{h}} = [x+(-y)]_{\stackrel{*}{h}} = [x]_{\stackrel{*}{h}} + [-y]_{\stackrel{*}{h}} \pmod{2}$$

已知[y]<sub>补</sub>求[一y]<sub>补</sub>的方法是: 将[y]<sub>补</sub>的所有位(包括符号位)一起取

反,然后在最低位加1(对定点小数相当于加 $2^{-n}$ ):

$$[-y]_{-} = -[y]_{+} + 2^{-n}$$

证明:

一求补运算

不同于求一个数的补码

(1)若y为正数,1 → y≥0。[y]<sub>补</sub>=0.y<sub>1</sub>y<sub>2</sub>...y<sub>n</sub>=y。

$$[-y]_{\nmid h} = 2 + (-y) = 2 - 0.y_1y_2...y_n$$

$$= 2^{-n} + (1.11...1 - 0.y_1y_2...y_n)$$

$$= -0.y_1y_2...y_n + 2^{-n}$$

(2) 若y为负数,0 > y > -1。 $[y]_{\uparrow \downarrow} = 1.y_1y_2...y_n = 2 + y$ 。

$$[-y]_{\nmid h} = -y = 2 - 1.y_1y_2...y_n$$

$$= 2^{-n} + (1.11...1 - 1.y_1y_2...y_n)$$

$$= -1.y_1y_2...y_n + 2^{-n}$$

例: 
$$x = -1110$$
,  $y = +1101$   $[x]_{\stackrel{?}{h}} = 10010$   $[-x]_{\stackrel{?}{h}} = 01110$   $[y]_{\stackrel{?}{h}} = 01101$   $[-y]_{\stackrel{?}{h}} = 10011$ 

例: 
$$x = +1101$$
,  $y = +0110$ , 求  $x - y$ 

$$[x]_{\dag} = 01101$$

$$[y]_{\dag} = 00110$$

$$[-y]_{\dag} = 11010$$

$$x - y = +0111$$

$$[x]_{\dag} = 01101$$

$$[x]_{\dag} = 01101$$

$$[x]_{\dag} = 01101$$

$$[x]_{\dag} = 01101$$

例: x = -1010,  $y = +1001 求[x]_{\stackrel{}{\uparrow}} [-x]_{\stackrel{}{\uparrow}} [y]_{\stackrel{}{\uparrow}} [-y]_{\stackrel{}{\uparrow}}$  求 $[x-y]_{\stackrel{}{\uparrow}}$ 

$$[x]_{\lambda} = 10110$$
  
 $[-x]_{\lambda} = 01010$   
 $[y]_{\lambda} = 01001$   
 $[-y]_{\lambda} = 10111$ 

溢出

#### 溢出检测

运算结果超出了机器允许的表示范围称为溢出。两个同符号数相加,如果结果的符号与参加运算的操作数的符号相反,则表明有溢出。两个正数相加产生的溢出称为上溢;两个负数相加产生的溢出称为下溢。

[例12] 
$$x = +0.1011$$
,  $y = +0.1001$ , 求  $x + y$ 。
[ $x$ ]补 $= 0.1011$  [ $y$ ]补 $= 0.1001$ 
[ $x$ ]补 $= 0.1001$ 
[ $x + y$ ]补 $= 0.1001$ 
[ $x + y$ ]补 $= 0.1000$ 
[例13]  $x = -0.1101$ ,  $y = -0.1011$ , 求  $x + y$ 。
[ $x$ ]补 $= 1.0011$  [ $y$ ]补 $= 1.0101$ 
[ $x + y$ ]补 $= 1.0101$ 
[ $x + y$ ]补 $= 0.1000$ 

#### 1.单符号位法

两个正数相加,最高有效位产生进位而符号位无进位(此时符号位从**0**变成**1**)则产生上溢;两个负数相加,最高有效位无进位而符号位有进位(此时符号位从**1**变成**0**)则产生下溢。

溢出逻辑表达式为:

$$V = C_f \oplus C_0$$

其中C<sub>1</sub>为符号位产生的进位,C<sub>0</sub>为最高有效位产生的进位。

#### 2.双符号位法

双符号位补码也称"变形补码"或"模4补码"。通过采用双符号位 ,可使所能表示的数的范围比模2补码扩大一倍。其定义为:

$$[x]_{\nmid h} = \begin{cases} X & 2 > X \ge 0 \\ 4 + X & 0 \ge X \ge -2 \end{cases} \pmod{4}$$

用 $S_{f1}$ 和 $S_{f2}$ 表示[x]<sub>补</sub>最高符号位和第二符号位,则:

$$S_{f1} S_{f2} = 00$$
  $0 \le x < 1$   
 $S_{f1} S_{f2} = 01$   $1 \le x < 2$   
 $S_{f1} S_{f2} = 11$   $-1 \le x < 0$   
 $S_{f1} S_{f2} = 10$   $-2 \le x < -1$ 

模4补码的运算规则为:

$$[x]_{k}+[y]_{k}=[x+y]_{k}\pmod{4}$$

若运算结果中 $S_{f1}$ 和 $S_{f2}$ 相同则无溢出;若 $S_{f1}S_{f2}$ =01表示上溢;若 $S_{f1}S_{f2}$ =10表示下溢。溢出逻辑表达式为 $S_{f1} \oplus S_{f2}$ 。无论是否溢出,最高符号位 $S_{f1}$ 永远表示运算结果的正确符号。

为了得到两数变形补码之和等于两数之和的变形补码,同样必须:

- 1. 两个符号位都看作数码一样参加运算
- 2. 两数进行以4位模的加法,即最高符号位上产生的进位要丢掉。

采用变形补码后,如果两个数相加后,其结果的符号位出现"01"或"10"两种组合时,表示发生溢出。这是因为两个绝对值小于1的数相加,其结果不会大于或等于2,所以最高符号位永远表示结果的正确符号。

采用变形补码后,正数的符号为00,负数的符号为11

两个符号位出现"01",表示已溢出,即结果大于+1。

两个符号位出现"10",表示已溢出,即结果小于一1。

### 用双符号位补码求解

$$x = +0.1101$$
,  $y = +0.1010$ ,  $\Re x + y$ 

[x]
$$\hbar=00.1101$$
, [y] $\hbar=00.1010$ 

[x]补 00.1101

+[y]补 00.1010

01.0111

两个符号位出现"01",表示已溢出,即结果大于+1。

两个二进制数字Ai, Bi和一个进位输入Ci相加,产生一个和输出Si, 以及一个进位输出C<sub>i+1</sub>。

表2.2 一位全加器真值表

|         | 输入      |         | 输出      |           |  |  |  |  |
|---------|---------|---------|---------|-----------|--|--|--|--|
| $A_{i}$ | $B_{i}$ | $C_{i}$ | $S_{i}$ | $C_{i+1}$ |  |  |  |  |
| 0       | 0       | 0       | 0       | 0         |  |  |  |  |
| 0       | 0       | 1       | 1       | 0         |  |  |  |  |
| 0       | 1       | 0       | 1       | 0         |  |  |  |  |
| 0       | 1       | 1       | 0       | 1         |  |  |  |  |
| 1       | 0       | 0       | 1       | 0         |  |  |  |  |
| 1       | 0       | 1       | 0       | 1         |  |  |  |  |
| 1       | 1       | 0       | 0       | 1         |  |  |  |  |
| 1       | 1       | 1       | 1       | 1         |  |  |  |  |

#### 一位全加器

全加器(Full Adder,FA)将两个二进制数字 $A_i$ 、 $B_i$ 和一个进位输入 $C_i$ 相加,产生一个和输出 $S_i$ ,以及一个进位输出 $C_{i+1}$ 。

$$S_i = A_i \oplus B_i \oplus C_i$$

$$C_{i+1} = A_i B_i + B_i C_i + C_i A_i = A_i B_i + (A_i \oplus B_i) C_i$$



### 门的延迟时间

常用门电路的国外常用符号和延迟时间。T表示一个与门或一个或门的延迟时间。

| 门  | 逻辑符号     | 延迟时间       |
|----|----------|------------|
| 与非 |          | T          |
| 或非 | <b>→</b> | T          |
| 非  | -        | T          |
| 与  |          | T          |
| 或  |          | T          |
| 异或 | ***      | 3 <i>T</i> |
| 同或 | ****     | 3 <i>T</i> |

对一位全加器来说, $S_i$ 的时间延迟为6T, $C_{i+1}$ 的时间延迟为5T。



考虑溢出检测时,延迟时间为 $T_a$ =3T+5T+(n-1)×2T+3T=(2n+9)T 不考虑溢出检测时,延迟时间为 $T_a$ =3T+5T+(n-2)×2T+3T=(2n+7)T

#### 先行进位加法器

行波进位加法器的进位延迟时间和字长成正比。为缩短进位时间,可采用先行进位方式(Carry Look Ahead,CLA)。

$$C_{i+1} = A_i B_i + (A_i \oplus B_i) C_i$$

定义

$$G_i = A_i B_i$$
,  $P_i = A_i \oplus B_i$ 

 $G_i$ 称为进位产生函数,含义是两个加数均为1时,必然向高位产生进位; $P_i$ 称为进位传递函数,含义是两个加数中有一个为1时,低位来的进位 $C_i$ 将超越本位向更高位传递。

$$\mathbf{C}_1 = \mathbf{G}_0 + \mathbf{P}_0 \mathbf{C}_0$$

$$C_2 = G_1 + P_1C_1 = G_1 + P_1G_0 + P_1P_0C_0$$

$$C_3 = G_2 + P_2C_2 = G_2 + P_2G_1 + P_2P_1G_0 + P_2P_1P_0C_0$$

$$C_4 = G_3 + P_3C_3 = G_3 + P_3G_2 + P_3P_2G_1 + P_3P_2P_1G_0 + P_3P_2P_1P_0C_0$$
各位进位可同时产生,与字长无关。但随着字长的增加, $C_i$ 的表达式

越来越复杂,而且受到元器件扇入系数的限制,所以完全采用先行进位是不现实的。

### 单级先行进位

当加法器字长较大时,可采用分组先行进位。以16位加法器为例,可分为4组,每组4位。第一组内的 $C_1$ 、 $C_2$ 、 $C_3$ 和 $C_4$ 通过CLA电路同时产生。 $C_4$ 产生后,作为第二组的进位输入,产生 $C_5$ 、 $C_6$ 、 $C_7$ 和 $C_8$ 。这种组内先行进位,组间串行进位的方式,称为单级先行进位。



单级先行进位电路中,进位延迟时间和组数成正比。组数越多,进位延迟时间越长。当字长较大(>16)时,有必要采用多级先行进位方式。

### 多级先行进位

多级先行进位是指组内和组间都采用先行进位。仍以16位加法器为例,第一小组的最高位进位 $C_4$ 可以写成:

$$C_4 = G_3 + P_3C_3 = G_3 + P_3G_2 + P_3P_2G_1 + P_3P_2P_1G_0 + P_3P_2P_1P_0C_0$$
  
=  $G_1^* + P_1^*C_0$ 

 $G^*_1$ 称为组进位产生函数, $P^*_1$ 称为组进位传递函数,它们只和 $P_i$ 、 $G_i$ 有关。

$$\begin{split} & C_4 = G_1^* + P_1^* C_0 \\ & C_8 = G_2^* + P_2^* C_4 = G_2^* + P_2^* G_1^* + P_2^* P_1^* C_0 \\ & C_{12} = G_3^* + P_3^* C_8 = G_3^* + P_3^* G_2^* + P_3^* P_2^* G_1^* + P_3^* P_2^* P_1^* C_0 \\ & C_{16} = G_4^* + P_4^* C_{12} = G_4^* + P_4^* G_3^* + P_4^* P_3^* G_2^* + P_4^* P_3^* P_2^* G_1^* + P_4^* P_3^* P_2^* P_1^* C_0 \end{split}$$

每个4位CLA加法器产生相应的组进位函数 $G^*_i$ 和 $P^*_i$ ,将这些组进位函数再送到CLA电路中,就可以同时产生 $C_4$ 、 $C_8$ 、 $C_{12}$ 和 $C_{16}$ 。



上图是一个两级先行进位的16位加法器。设与门和或门的延迟时间均为 $T_y$ ,该电路的工作过程是: 先产生 $G_i$ 和 $P_i$ ( $i=0\sim15$ ),经过2 $T_y$ 后产生所有的组进位函数 $G^*_i$ 和 $P^*_i$ ( $i=1\sim4$ )以及第一组的 $C_1$ 、 $C_2$ 和 $C_3$ ,再经过2 $T_y$ ,由CLA电路产生 $C_4$ 、 $C_8$ 、 $C_{12}$ 和 $C_{16}$ ,再经过2 $T_y$ ,产生第2、3、4组的 $C_5\sim C_7$ 、 $C_9\sim C_{11}$  和 $C_{13}\sim C_{15}$ 。

用同样办法可构造多级先行进位加法器,如用三级先行进位结构设计 64位加法器,这种加法器的字长对加法时间影响甚小。

#### 十进制加法器



#### 两个一位十进制数相加,并考虑低位的进位,结果范围0~19。

| 和 | 加法器输出 |       |       |       |       | 修正后输出 |                |                |                | **             | 加法器输出 |    |       |       |       | 修正后输出 |   |     |                |                |    |
|---|-------|-------|-------|-------|-------|-------|----------------|----------------|----------------|----------------|-------|----|-------|-------|-------|-------|---|-----|----------------|----------------|----|
|   | C'    | $S_3$ | $S_2$ | $S_1$ | $S_0$ | С     | S <sub>3</sub> | S <sub>2</sub> | S <sub>1</sub> | S <sub>0</sub> | 和     | C' | $S_3$ | $S_2$ | $S_1$ | $S_0$ | С | S 3 | S <sub>2</sub> | S <sub>1</sub> | So |
| 0 | 0     | 0     | 0     | 0     | 0     | 0     | 0              | 0              | 0              | 0              | 10    | 0  | 1     | 0     | 1     | 0     | 1 | 0   | 0              | 0              | 0  |
| 1 | 0     | 0     | 0     | 0     | 1     | 0     | 0              | 0              | 0              | 1              | 11    | 0  | 1     | 0     | 1     | 1     | 1 | 0   | 0              | 0              | 1  |
| 2 | 0     | 0     | 0     | 1     | 0     | 0     | 0              | 0              | 1              | 0              | 12    | 0  | 1     | 1     | 0     | 0     | 1 | 0   | 0              | 1              | 0  |
| 3 | 0     | 0     | 0     | 1     | 1     | 0     | 0              | 0              | 1              | 1              | 13    | 0  | 1     | 1     | 0     | 1     | 1 | 0   | 0              | 1              | 1  |
| 4 | 0     | 0     | 1     | 0     | 0     | 0     | 0              | 1              | 0              | 0              | 14    | 0  | 1     | 1     | 1     | 0     | 1 | 0   | 1              | 0              | 0  |
| 5 | 0     | 0     | 1     | 0     | 1     | 0     | 0              | 1              | 0              | 1              | 15    | 0  | 1     | 1     | 1     | 1     | 1 | 0   | 1              | 0              | 1  |
| 6 | 0     | 0     | 1     | 1     | 0     | 0     | 0              | 1              | 1              | 0              | 16    | 1  | 0     | 0     | 0     | 0     | 1 | 0   | 1              | 1              | 0  |
| 7 | 0     | 0     | 1     | 1     | 1     | 0     | 0              | 1              | 1              | 1              | 17    | 1  | 0     | 0     | 0     | 1     | 1 | 0   | 1              | 1              | 1  |
| 8 | 0     | 1     | 0     | 0     | 0     | 0     | 1              | 0              | 0              | 0              | 18    | 1  | 0     | 0     | 1     | 0     | 1 | 1   | 0              | 0              | 0  |
| 9 | 0     | 1     | 0     | 0     | 1     | 0     | 1              | 0              | 0              | 1              | 19    | 1  | 0     | 0     | 1     | 1     | 1 | 1   | 0              | 0              | 1  |

#### 十进制加法器

在十进制运算时,当相加二数之和大于9时,便产生进位。可是用BCD码完成十进制数运算时,当和数大于9时,必须对和数进行加6修正。这是因为,采用BCD码后,在二数相加的和数小于等于9时,十进制运算的结果是正确的;而当相加的和数大于9时,结果不正确,必须加6修正后才能得出正确的结果。





例如: X=15 (D) Y=26 (D) 计算 Z = X+Y = 41(D)

$$X0=5 = 0101$$

$$Y0=6 = 0110$$

$$X1=1=0001$$

$$Y1=2=0010$$

修正之后应该为:

$$C1=1$$

若不进行修正,结果为S0=X0+Y0=B(H)=1011 S1=X1+Y1=3(H) =0011

```
作业
P61
5(2) 6(2)(3) 13
5(3) 6(1) 12
```

### 原码乘法

#### 1.人工算法与机器算法的同异性

两个原码表示的数相乘的运算规则是:乘积的符号位由两数的符号位按异或运算得到,而乘积的数值部分则是两个正数相乘之积。

被乘数: 
$$[x]_{\mathbb{R}} = x_f . x_{n-1} ... x_1 x_0$$

乘数: 
$$[y]_{\mathbb{F}} = y_f \cdot y_{n-1} \dots y_1 y_0$$

乘积: 
$$[z]_{\mathbb{F}} = (x_f \oplus y_f) + (0.x_{n-1}...x_1x_0)(0.y_{n-1}...y_1y_0)$$

例: x=0.1101, y=0.1011:

例对于只有加法器 和移位器的计算机,可以 通过多次执行"加法一移 位"操作来实现乘法。

#### 2.不带符号的阵列乘法器

设A和B是m位和n位的不带符号的二进制整数,相乘产生m+n位乘积P:

$$A = a_{m-1}...a_1a_0,$$
  $B = b_{n-1}...b_1b_0$   
 $P = p_{m+n-1}...p_1p_0$ 

则乘积P的数值为:

$$P = (\sum_{i=0}^{m-1} a_i 2^i)(\sum_{j=0}^{n-1} b_j 2^j) = \sum_{i=0}^{m-1} \sum_{j=0}^{n-1} (a_i b_j) 2^{i+j} = \sum_{k=0}^{m+n-1} p_k 2^k$$

|                       |                |                       |                       |                            | <b>a</b> 4        | az                         | $\mathbf{a}_2$             | $a_1$                      | $\mathbf{a_0}$             |                            |
|-----------------------|----------------|-----------------------|-----------------------|----------------------------|-------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|
|                       |                |                       |                       | ×                          | $\mathbf{b_4}$    | $\mathbf{b}_3$             | $\mathbf{b_2}$             | $\mathbf{b_1}$             | $\mathbf{b_0}$             |                            |
|                       |                |                       |                       |                            |                   | $a_3b_0$                   |                            |                            | $\mathbf{a}_0\mathbf{b}_0$ | $\mathbf{a_{i}}\mathbf{b}$ |
|                       |                |                       |                       | $\mathbf{a_4}\mathbf{b_1}$ | $\mathbf{a_3b_1}$ | $\mathbf{a_2}\mathbf{b_1}$ | $\mathbf{a_1}\mathbf{b_1}$ | $\mathbf{a_0}\mathbf{b_1}$ |                            |                            |
|                       |                |                       | $a_4b_2$              | $a_3b_2$                   | $a_2b_2$          | $a_1b_2$                   | $a_0b_2$                   |                            |                            | 位积可                        |
|                       |                | $a_4b_3$              | $a_3b_3$              | $\mathbf{a_2}\mathbf{b_3}$ | $a_1b_3$          | $a_0b_3$                   |                            |                            |                            | 并行产                        |
| +                     | $a_4b_4$       | $a_3b_4$              | $a_2b_4$              | $a_1b_4$                   | $a_0b_4$          |                            |                            |                            |                            | 21 1 <b>4</b> /            |
| <b>p</b> <sub>9</sub> | p <sub>8</sub> | <b>p</b> <sub>7</sub> | <b>p</b> <sub>6</sub> | <b>p</b> <sub>5</sub>      | p <sub>4</sub>    | <b>p</b> <sub>3</sub>      | p <sub>2</sub>             | <b>p</b> <sub>1</sub>      | $\mathbf{p}_0$             |                            |
|                       |                |                       |                       |                            |                   |                            |                            |                            |                            |                            |

a<sub>i</sub>b<sub>j</sub>称为位积。m×n个 位积可以通过m×n个与门 并行产生。

#### 2.不带符号的阵列乘法器



a<sub>i</sub>b<sub>j</sub>称为位积。m×n个 位积可以通过m×n个与门 并行产生。



### 对2求补电路

对2求补时,采用自右向左按位扫描技术。设 $A=a_n...a_1a_0$ 是 (n+1)位带符号数的原码, $a_n$ 为符号位,要求确定它的补码。求补的方法是从数的最右端 $a_0$ 开始,从右向左扫描,直到找出第一个"1"。例如 $a_i=1$ , $a_i$ 左侧的每一个数值位都取反, $a_i$ 和 $a_i$ 右侧的位保持不变。当控制信号线E为"1"时,启动对2求补的操作;当控制信号线E为"0"时,输出和输入相等。可以利用符号位来作为控制信号。



E(接符号位a<sub>4</sub>)  $a^*$  的延迟时间为:

$$t_{\text{TC}} = n \times T + T + 3T$$
$$= (n+4)T$$

若输入为带符号数的补码,则输出为该数的原码,即

#### 3.带符号的阵列乘法器



算前求补器的作用是将乘数 和被乘数补码变成原码;算后求 补器的作用是将乘法阵列输出的 乘积原码变成补码。

例: x = -15, y = -13, 用带 求补器的阵列乘法器求xy。

[x]<sub>补</sub>=10001, [y]<sub>补</sub>=10011 算前求补器输出为:

$$|x|=1111, |y|=1101$$

阵列乘法器输出为:

11000011

乘积的符号位为**0**,算后求补器 输出为:

11000011

乘积的补码为:

 $[xy]_{k} = 011000011$ 

## 思考

1、"求补"与求一个数补码有何异同之处?

2、何时用"求补"运算,何时用"求补码"?

# 补码与真值的关系

考虑一个定点补码整数  $[N]_{i}=a_{n}a_{n-1}...a_{1}a_{0}$ ,其中 $a_{n}$ 是符号位。  $[N]_{i}$ 和真值N的关系可以表示成:

$$N = \begin{cases} +\sum_{i=0}^{n-1} a_i 2^i & a_n = 0 \\ -[1+\sum_{i=0}^{n-1} (1-a_i)2^i] = -2^n + \sum_{i=0}^{n-1} a_i 2^i & a_n = 1 \end{cases}$$
  
二两式可合并成下列形式:

以上两式可合并成下列形式:

$$N = -a_n 2^n + \sum_{i=0}^{n-1} a_i 2^i$$

因此可以认为符号位a<sub>n</sub>具有负的权值(-2<sup>n</sup>),而数值位a<sub>i</sub>具有正的权值(+2<sup>i</sup>)。 另外,一N的值可以用下式计算:

$$[-N]_{\nmid h} = \overline{a_n} \, \overline{a_{n-1}} \, \Lambda \, \overline{a_1} \, \overline{a_0} + 1$$

$$-N = -(1 - a_n) 2^n + [\sum_{i=0}^{n-1} (1 - a_i) 2^i] + 1$$

## 般化的全加器

| 类型                 | 逻辑符号    | 操作                                   |
|--------------------|---------|--------------------------------------|
| <b>0</b> 类<br>全加器  | X Y Z   | X<br>Y<br><u>+) Z</u><br>CS          |
| <b>1</b> 类<br>全加器  | X Y Z S | X<br>Y<br><u>+)-Z</u><br>C(-S)       |
| 2类<br>全加器<br>(全减器) |         | -x<br>-y<br><u>+) Z</u><br>(−C)S     |
| <b>3</b> 类<br>全加器  | X Y Z S | -X<br>-Y<br><u>+) -Z</u><br>(-C)(-S) |

通过把正权或负权加到全加器的输入/输 出端,可以归纳出四类加法器。每一类加法

C为1表示"2", S为1表示 "一1",因此结果为"1" 其真值表为:

个数命名。

| X (+) | Yt | (-) | S (-) | C(+) |
|-------|----|-----|-------|------|
| 0     | 0  |     | 0     | 0    |
| 0     | 0  | 1   | 1     | 0    |
| 0     | 1  | 0   | 1     | 1    |
| 0     | 1  | 1   | 0     | 0    |
| 1     | 0  | 0   | 1     | 1    |
| 1     | 0  | 1   | 0     | 0    |
| 1     | 1  | 0   | 0     | 1    |
| 1     | 1  | 1   | 1     | 1    |

对0类、3类全加器:

$$S = \overline{X} \overline{Y} Z + \overline{X} Y \overline{Z} + X \overline{Y} \overline{Z} + X Y Z$$

$$C = XY + YZ + XZ$$

对1类、2类全加器:

$$S = \overline{X} \overline{Y} Z + \overline{X} Y \overline{Z} + X \overline{Y} \overline{Z} + X Y Z$$

$$C = XY + Y \overline{Z} + X \overline{Z}$$

## 直接补码阵列乘法器

设被乘数A和乘数B是两个5位的二进制补码数,即

$$A=(a_4)a_3a_2a_1a_0$$
,  $B=(b_4)b_3b_2b_1b_0$ 

它们具有带负权的符号位 $a_4$ 和 $b_4$ (用括号标注)。将符号位一起参加运算,并用括号标注具有负权的位积,则A和B相乘的计算过程如下:

### 利用一般化的全加器可以构成直接补码阵列乘法器:



右上角的三角形用0类全加器,左上角的三角形用1类全加器,最后两行用2类全加器。结果的最高位p<sub>9</sub>具有负权,所以结果为补码。

作业

P61 7 (1)

## 原码除法

$$[x]_{\mathbb{R}} = x_f . x_{n-1} ... x_1 x_0, [y]_{\mathbb{R}} = y_f . y_{n-1} ... y_1 y_0$$

则商q=x/y的原码为:

$$[q]_{\mathbb{R}} = (x_f \oplus y_f) + (0.x_{n-1}...x_1x_0 / 0.y_{n-1}...y_1y_0)$$

例:被除数x=0.1001,除数y=0.1011。手工计算x/y的过程如下:

| 0. 1 1 0 1                                            |                        |
|-------------------------------------------------------|------------------------|
| 0. 1 0 1 1 0. 1 0 0 1                                 |                        |
| -0.1011                                               | x < y,商0               |
| 0. 1 0 0 1 0                                          | 得余数r <sub>0</sub> (即x) |
| -0.01011                                              | 除数右移一位,余数减除数,商1        |
| 0. 0 0 1 1 1 0                                        | 得余数r <sub>1</sub>      |
| -0.001011                                             | 除数右移一位,余数减除数,商1        |
| 0. 0 0 0 0 1 1 0                                      | 得余数r <sub>2</sub>      |
| -0.0001011                                            | 除数右移一位,余数不减除数,商0       |
| 0. 0 0 0 0 1 1 0 0                                    | 得余数r <sub>3</sub>      |
| $-0. \ 0 \ 0 \ 0 \ 1 \ 0 \ 1 \ 1$                     | 除数右移一位,余数减除数,商1        |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | 得余数r₄                  |

# 恢复余数法

被除数x=0.1001,除数v=0.1011 [-v] \* 1.0101

为保证余数左移时符号位 变,应采用双符号位

(1) 将心算比较余数和

并且减y改为加[-y]<sub>补</sub>。余

除数大小改为减法比较,

数减除数大于等于0则商1

,小于0则商0。

(2) 将除数右移改为余 数左移。

如果余数减除数的差 小于0,应将差加上除数 ,恢复原来的余数。这就 是恢复余数法。

|   |                     | 0.1   |   | • , | 1X) | · <i>&gt;</i> >> | 0.1011 |                        |
|---|---------------------|-------|---|-----|-----|------------------|--------|------------------------|
| _ |                     | 0 0.  | 1 | 0   | 0   | 1                | 商      | 说明                     |
| 7 | <mark>在一y]补</mark>  | 1 1.  | 0 | 1   | 0   | 1                |        | x—y                    |
| • |                     | 1 1.  | 1 | 1   | 1   | 0                | 0      | 余数 $r_0 < 0$ ,商        |
| _ | +                   | -0 0. | 1 | 0   | 1   | 1                |        | 加y恢复余数                 |
|   |                     | 0 0.  | 1 | 0   | 0   | 1                |        |                        |
|   | _                   | 0 1.  | 0 | 0   | 1   | 0                |        | 余数左移一位                 |
|   | +[−y] <sub>ネト</sub> | 1 1.  | 0 | 1   | 0   | 1                |        | 减y比较                   |
|   |                     | 0 0.  | 0 | 1   | 1   | 1                | 0.1    | 余数 $r_1 > 0$ ,商        |
|   | <b>←</b>            | 0 0.  | 1 | 1   | 1   | 0                |        | 余数左移一位                 |
|   | +[-y] <sub>ネト</sub> | 1 1.  | 0 | 1   | 0   | 1_               |        | 减y比较                   |
|   |                     | 0 0.  | 0 | 0   | 1   | 1                | 0.11   | 余数r <sub>2</sub> > 0,商 |
|   | <b>←</b>            | 0 0.  | 0 | 1   | 1   | 0                |        | 余数左移一位                 |
|   | +[−y] <sub>ネト</sub> | 1 1.  | 0 | 1   | 0   | 1                |        | 减y比较                   |
|   |                     | 1 1.  | 1 | 0   | 1   | 1                | 0.110  | 余数r <sub>3</sub> < 0,商 |
|   | +                   | -0 0. | 1 | 0   | 1   | 1                |        | 加y恢复余数                 |
|   |                     | 0 0.  | 0 | 1   | 1   | 0                |        |                        |
|   | <b>←</b>            | 0 0.  | 1 | 1   | 0   | 0                |        | 余数左移一位                 |
|   | +[-y] <sub>ネ⊦</sub> | 1 1.  | 0 | 1   | 0   | 1                |        | 减y比较                   |
|   |                     | 0 0.  | 0 | 0   | 0   | 1                | 0.1101 | 余数r <sub>4</sub> > 0,商 |
|   |                     |       |   |     |     |                  |        |                        |

## 加减交替法

恢复余数法中,设某次余数为r<sub>i</sub>,要继续进行下面的求商运算,需要将r<sub>i</sub>左移一位,然后减去除数,进行比较:

结果小于0时商上0,并加y恢复余数:

$$(2r_i-y)+y=2r_i$$

继续下面的求商,又要将它左移一位,再减去除数

$$2(2r_i)-y=4r_i-y$$

当(2r<sub>i</sub>-y)小于0时,商仍上0,但不进行加y恢复余数的操作,而是将(2r<sub>i</sub>-y)左移一位,然后加上除数

$$2(2r_i-y)+y=4r_i-y$$

也得到同样的余数(4r<sub>i</sub>-y)。所以,当比较结果小于0时,仍将结果左移一位,然后加上除数y。这就是不恢复余数法,也称加减交替法。

加减交替法的运算规则是:

余数为正时,商上1,余数左移一位,再减去除数,得到新的余数; 余数为负时,商上0,余数左移一位,再加上除数,得到新的余数。

余数:

注意: 得到的余数是经过左移4次后的结果

故余数为 0.0001 × 2 - 4

## 恢复余数法的运算规则是:

余数为正时,商上1,余数左移一位,再减去除数,得到新的余数; 余数为负时,商上0,再加上除数(恢复余数),余数左移一位,再 减去除数,得到新的余数。

## 加减交替法的运算规则是:

余数为正时,商上1,余数左移一位,再减去除数,得到新的余数; 余数为负时,商上0,余数左移一位,再加上除数,得到新的余数。

证明: 2(R+y) - y = 2R + y特点:

- 1、恢复余数除法,最后的操作为减法
- 2、都需要余数左移一位后再进行加或减



余数的绝对值小于除数的绝对值

84

## 可控加法/减法单元

可控加法/减法单元(CAS)由一个全加器和一个异或门构成,有4个输入端和4个输出端。当控制端P为0时,实现全加器:

$$S_i = A_i \oplus B_i \oplus C_i$$

$$C_{i+1} = A_i B_i + B_i C_i + A_i C_i$$

控制端为1时,用于实现补码减法:

$$S_i {=} A_i {\oplus} B_i {\oplus} C_i$$

$$C_{i+1} = A_i \overline{B}_i + \overline{B}_i C_i + A_i C_i$$

设 $[x]_{\uparrow}=0.x_1x_2x_3$ , $[y]_{\uparrow}=0.y_1y_2y_3$ 。下图电路当P=0时实现x+y,P=0

=1时实现x-y。减法是通过加上 $[-y]_{\lambda}$ 实现的。







## 阵列除法器

利用CAS构成的不恢复余数阵列除法器如下。被除数 $x=0.x_1x_2x_3x_4x_5x_6$ ,除数 $y=0.y_1y_2y_3$ ,均为正数,且x<y(否则商大于1,溢出)。



2n位除以n位的阵列除法器,有单元(n+1) $^2$ 个,延迟时间为 $t_d$ =(n+1) $^2$  $T_{CAS}$ 。

# 阵列除法器

上一行余数小于除数则不产生进位,q<sub>i</sub>=0,下一行做加法。 "不够减",不产生进位,例 3 – 5,转化为 3 + (–5)补

上一行余数大于除数则产生进位,qi=1,下一行做减法。"够减",产生进位,例 5-3,转化为 5+(-3)补

作业

P61 8 (2)

用恢复余数与加减交替法分别计算

# 逻辑运算

设 
$$\mathbf{x} = \mathbf{x}_0 \mathbf{x}_1 \mathbf{x}_2 \dots \mathbf{x}_n$$

$$z = \overline{x} = z_0 z_1 z_2 ... z_n$$

则 
$$z_i = \overline{x_i}$$
 (i=0,1,2,...,n)

## 2.逻辑加运算

设 
$$\mathbf{x} = \mathbf{x_0} \mathbf{x_1} \mathbf{x_2} \dots \mathbf{x_n}$$

$$y = y_0 y_1 y_2 ... y_n$$

$$z=x \vee y=z_0z_1z_2...z_n$$

$$\mathbf{z}_{i} = \mathbf{x}_{i} \vee \mathbf{y}_{i}$$

则 
$$\mathbf{z}_i = \mathbf{x}_i \vee \mathbf{y}_i$$
 (i=0,1,2,...,n) 用符号+或者 $\vee$ 来表示

## 3.逻辑乘运算

设 
$$\mathbf{x} = \mathbf{x_0} \mathbf{x_1} \mathbf{x_2} \dots \mathbf{x_n}$$

$$y=y_0y_1y_2...y_n$$

$$z=x \wedge y=z_0z_1z_2...z_n$$

则 
$$z_i = x_i \wedge y_i$$
 (i=0,1,2,...,n) 用符号+或者:来表示

## 4.逻辑异运算

设 
$$\mathbf{x} = \mathbf{x_0} \mathbf{x_1} \mathbf{x_2} \dots \mathbf{x_n}$$

$$y = y_0 y_1 y_2 ... y_n$$

$$z=x\oplus y=z_0z_1z_2...z_n$$

则 
$$\mathbf{z}_i = \mathbf{x}_i \oplus \mathbf{y}_i$$
  $(i = 0, 1, 2, ..., n)$  用符号 $\oplus$ 来表示

# 多功能算术逻辑单元

算术逻辑运算单元(Arithmetic Logic Unit, ALU)不仅具有多种算术运算和逻辑运算的功能,而且具有先行进位逻辑,从而能实现高速运算。

全加器的逻辑表达式为:

$$F_i = A_i \oplus B_i \oplus C_i$$

$$C_{i+1} = A_i B_i + B_i C_i + A_i C_i$$

为了对全加器进行功能扩展以完成多种算术和逻辑运算,将 $A_i$ 和 $B_i$  送到由 $S_0$ , $S_1$ , $S_2$ , $S_3$ 控制的函数发生器内,产生组合函数 $X_i$ 和 $Y_i$ ,再送到全加器内进行全加:

$$F_i = X_i \oplus Y_i \oplus C_{n+i}$$

 $C_{n+i+1} = X_i Y_i + X_i C_{n+i} + Y_i C_{n+i}$ 进位下标用n+i代替i,n表示多片级 联时每片的进位输入。



| $S_0$ | $S_1$ | $Y_{i}$                          | $S_2$ $S_3$ | $X_{i}$                           |
|-------|-------|----------------------------------|-------------|-----------------------------------|
| 0     | 0     | $\overline{A_i}$                 | 0 0         | 1                                 |
| 0     | 1     | $\overline{A_i}B_i$              | 0 1         | $\overline{A_i} + \overline{B_i}$ |
| 1     | 0     | $\overline{A_i}  \overline{B_i}$ | 1 0         | $\overline{A_i} + B_i$            |
| 1     | 1     | 0                                | 1 1         | $\overline{A_i}$                  |

## X<sub>i</sub>和Y<sub>i</sub>的逻辑表达式为:

$$\begin{aligned} \mathbf{X}_{\mathbf{i}} &= \overline{\mathbf{S}}_{2} \overline{\mathbf{S}}_{3} + \overline{\mathbf{S}}_{2} \mathbf{S}_{3} \ (\overline{\mathbf{A}}_{\mathbf{i}} + \overline{\mathbf{B}}_{\mathbf{i}}) \ + \mathbf{S}_{2} \overline{\mathbf{S}}_{3} \ (\overline{\mathbf{A}}_{\mathbf{i}} + \mathbf{B}_{\mathbf{i}}) \ + \mathbf{S}_{2} \mathbf{S}_{3} \overline{\mathbf{A}}_{\mathbf{i}} \\ \mathbf{Y}_{\mathbf{i}} &= \overline{\mathbf{S}}_{0} \overline{\mathbf{S}}_{1} \overline{\mathbf{A}}_{\mathbf{i}} + \overline{\mathbf{S}}_{0} \mathbf{S}_{1} \overline{\mathbf{A}}_{\mathbf{i}} \mathbf{B}_{\mathbf{i}} + \mathbf{S}_{0} \mathbf{S}_{1} \overline{\mathbf{A}}_{\mathbf{i}} \overline{\mathbf{B}}_{\mathbf{i}} \end{aligned}$$

$$\mathbf{X}_{i} = \overline{\mathbf{S}_{3} \mathbf{A}_{i} \mathbf{B}_{i} + \mathbf{S}_{2} \mathbf{A}_{i} \overline{\mathbf{B}_{i}}}$$

$$\mathbf{Y}_{i} = \overline{\mathbf{A}_{i} + \mathbf{S}_{0} \mathbf{B}_{i} + \mathbf{S}_{1} \overline{\mathbf{B}_{i}}}$$

### 另外还有:

$$\mathbf{X}_{i} + \mathbf{Y}_{i} = \mathbf{X}_{i}$$
$$\mathbf{X}_{i} \mathbf{Y}_{i} = \mathbf{Y}_{i}$$

因此全加器的进位信号可以写成:

$$C_{n+i+1} = X_i Y_i + (X_i + Y_i) C_{n+i} = Y_i + X_i C_{n+i}$$

4位之间采用先行进位逻辑,每一位的进位公式递推如下:

$$\begin{split} &C_{n+1} = Y_0 + X_0 C_n \\ &C_{n+2} = Y_1 + X_1 C_{n+1} = Y_1 + X_1 Y_0 + X_1 X_0 C_n \\ &C_{n+3} = Y_2 + X_2 C_{n+2} = Y_2 + X_2 Y_1 + X_2 X_1 Y_0 + X_2 X_1 X_0 C_n \\ &C_{n+4} = Y_3 + X_3 C_{n+3} = Y_3 + X_3 Y_2 + X_3 X_2 Y_1 + X_3 X_2 X_1 Y_0 + X_3 X_2 X_1 X_0 C_n \end{split}$$

定义

$$G = Y_3 + X_3Y_2 + X_3X_2Y_1 + X_3X_2X_1Y_0$$

$$P = X_3X_2X_1X_0$$

G称为进位产生输出,P称为进位传递输出,它们和CLA电路配合使用,可以实现多级先行进位。

74181是4位算术逻辑单元。它除了有 $S_0 \sim S_3$ 四个控制端外,还有一个控制端M,用来控制74181是进行算术运算还是进行逻辑运算。74181既适用于正逻辑数的运算,也适用于负逻辑数的运算。还有一个输出端"A=B"可用于检测两数相等。





以正逻辑为例。当M=H(高电平)时,各位的输出表达式为:

$$F_i = X_i \oplus Y_i \oplus 1$$
  $i = 0,1,2,3$ 

此时Fi只和Xi及Yi有关,与进位信号无关,实现逻辑运算。

当M=L(低电平)时,各位的输出表达式为:

$$F_{i} = X_{i} \oplus Y_{i} \oplus \overline{C_{n+i}}$$

$$= \overline{X_{i}} \oplus \overline{Y_{i}} \oplus \overline{C_{n+i}}$$

$$i = 0,1,2,3$$

而 $\overline{X_i}$ 、 $\overline{Y_i}$ 和 $\overline{C_{n+i}}$ 相加产生的进位刚好为 $\overline{C_{n+i+1}}$ ,此时74181实现算术运算:

 $C_n = H$ 无进位输入,74181实现  $\overline{X}_3 \overline{X}_2 \overline{X}_1 \overline{X}_0$ 加  $\overline{Y}_3 \overline{Y}_2 \overline{Y}_1 \overline{Y}_0$ ;

 $C_n = L$ 有进位输入,74181实现  $\overline{X}_3 \overline{X}_2 \overline{X}_1 \overline{X}_0$ 加  $\overline{Y}_3 \overline{Y}_2 \overline{Y}_1 \overline{Y}_0$ 加1。

以正逻辑为例。当M=H(高电平)时,各位的输出表达式为:

$$F_i = X_i \oplus Y_i \oplus 1$$
  $i = 0,1,2,3$ 

当M=L(低电平)时,各位的输出表达式为:

74181实现算术运算:

 $C_n = H$ 无进位输入,74181实现  $X_3X_2X_1X_0$ 加  $Y_3Y_2Y_1Y_0$ ;

C<sub>n</sub>=L有进位输入,74181实现 X<sub>3</sub>X<sub>2</sub>X<sub>1</sub>X<sub>0</sub>加 Y<sub>3</sub>Y<sub>2</sub>Y<sub>1</sub>Y<sub>0</sub>加1。

$$F_{i} = X_{i} \oplus Y_{i} \oplus \overline{C_{n+i}}$$

$$= \overline{X_{i}} \oplus \overline{Y_{i}} \oplus \overline{C_{n+i}} \qquad i = 0,1,2,3$$

## 全加器的逻辑表达式为:

$$F_i = A_i \oplus B_i \oplus C_i$$

$$C_{i+1} = A_i B_i + B_i C_i + A_i C_i$$

每一级需要的进位信号为上一级的加数两两相乘之和

$$F_i = X_i \oplus Y_i \oplus C_{n+i}$$

$$\begin{aligned} & \textbf{F}_0 \!\!=\! \textbf{X}_0 \!\!\oplus\! \textbf{Y}_0 \!\!\oplus\! \textbf{C}_{\underline{n}} \\ & \textbf{F}_1 \!\!=\! \textbf{X}_1 \!\!\oplus\! \textbf{Y}_1 \!\!\oplus\! \textbf{C}_{\underline{n+1}} \\ & \textbf{F}_2 \!\!=\! \textbf{X}_2 \!\!\oplus\! \textbf{Y}_2 \!\!\oplus\! \textbf{C}_{\underline{n+2}} \\ & \textbf{F}_3 \!\!=\! \textbf{X}_3 \!\!\oplus\! \textbf{Y}_3 \!\!\oplus\! \textbf{C}_{\underline{n+3}} \end{aligned}$$

$$\begin{array}{c}
C_{n+1} = X_0 Y_0 + Y_0 C_{n} + X_0 C_{n} \\
C_{n+2} = X_1 Y_1 + Y_1 C_{n+1} + X_1 C_{n+1} \\
C_{n+3} = X_2 Y_2 + Y_2 C_{n+2} + X_2 C_{n+2}
\end{array}$$

$$\begin{aligned} &\textbf{F}_{i} = \overline{\textbf{X}}_{i} \oplus \overline{\textbf{Y}}_{i} \oplus \overline{\textbf{C}}_{n+i} \\ &\textbf{F}_{0} = \overline{\textbf{X}}_{0} \oplus \overline{\textbf{Y}}_{0} \oplus \overline{\textbf{C}}_{n} \\ &\textbf{F}_{1} = \overline{\textbf{X}}_{1} \oplus \overline{\textbf{Y}}_{1} \oplus \overline{\textbf{C}}_{n+1} \\ &\textbf{F}_{2} = \overline{\textbf{X}}_{2} \oplus \overline{\textbf{Y}}_{2} \oplus \overline{\textbf{C}}_{n+2} \\ &\textbf{F}_{3} = \overline{\textbf{X}}_{3} \oplus \overline{\textbf{Y}}_{3} \oplus \overline{\textbf{C}}_{n+3} \end{aligned}$$

$$C_{n+1} = X_{0}Y_{0} + Y_{0}C_{n} + X_{0}C_{n}$$

$$C_{n+2} = X_{1}Y_{1} + Y_{1}C_{n+1} + X_{1}C_{n+1}$$

$$C_{n+3} = X_{2}Y_{2} + Y_{2}C_{n+2} + X_{2}C_{n+2}$$

$$\overline{X_i}$$
、 $\overline{Y_i}$ 和  $\overline{C_{n+i}}$ 相加产生的进位为:  $\overline{X_i}\overline{Y_i}+\overline{X_i}\overline{C_{n+i}}+\overline{Y_i}\overline{C_{n+i}}=$   $\overline{X_i}+\overline{Y_i}+\overline{X_i}\overline{C_{n+i}}+\overline{Y_i}\overline{C_{n+i}}=$   $\overline{X_i}+\overline{X_i}\overline{C_{n+i}}+\overline{Y_i}\overline{C_{n+i}}=\overline{X_i}+\overline{Y_i}\overline{C_{n+i}}$ 

$$\overline{C_{n+i+1}} = \underline{Y_i} + \underline{X_i} \underline{C_{n+i}}$$

$$= \underline{Y_i} \cdot \underline{X_i} \underline{C_{n+i}}$$

$$= \underline{Y_i} \cdot (\underline{X_i} + \underline{C_{n+i}})$$

$$= \underline{Y_i} \underline{X_i} + \underline{Y_i} \underline{C_{n+i}}$$

$$= \underline{Y_i} + \underline{X_i} + \underline{Y_i} \underline{C_{n+i}}$$

$$= \underline{X_i} + \underline{Y_i} \underline{C_{n+i}}$$

故 $X_i$ 、 $Y_i$ 和 $C_{n+i}$ 相加产生的进位刚好为 $C_{n+i+1}$ 

**例:** 正逻辑方式下,S<sub>3</sub>S<sub>2</sub>S<sub>1</sub>S<sub>0</sub>=LHLL,M=H,74181实现何种运算? M=H时,输出表达式为: F<sub>i</sub>=X<sub>i</sub>⊕Y<sub>i</sub>⊕1

 $S_3S_2S_1S_0=LHLL时,<math>X_i=\overline{A_i}+B_i$ , $Y_i=\overline{A_i}$ ,所以  $F_i=(\overline{A_i}+B_i)\oplus \overline{A_i}\oplus 1=\overline{A_i}\overline{B_i}$ 

故此时74181实现逻辑运算AB。如果把输出表达式中"与""或"互换、"同或""异或"互换、"0""1"互换(即求对偶),得到的就是负逻辑方式下电路实现的逻辑运算,所以此时电路在负逻辑方式下实现的逻辑运算为A+B。

例:正逻辑方式下, $S_3S_2S_1S_0=HLLL$ ,M=L,74181实现何种运算? M=L时,电路实现算术运算 $X_i$ 加 $Y_i$ 。

 $S_3S_2S_1S_0=HLLL时,<math>X_i=\overline{A_i}+\overline{B_i}$ , $Y_i=\overline{A_i}$ ,所以

 $C_n$ =H时,电路实现AB加A; $C_n$ =L时,电路实现AB加A加1。

正逻辑下的全加运算在负逻辑下仍是全加运算。负逻辑方式下的功能为:

 $C_n = H$  时实现(A+B)加A加1,相当于有进位;

100 C<sub>n</sub>=L 时实现 (A+B)加A,相当于无进位。

| 工作方式                                                                | 1                                         | 负逻辑                                 | 正逻辑                                       |                                    |  |
|---------------------------------------------------------------------|-------------------------------------------|-------------------------------------|-------------------------------------------|------------------------------------|--|
| 选择输入<br>S <sub>3</sub> S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> | 逻辑运算<br>M=H                               | 算术运算<br>M=L, C <sub>n</sub> =L(无进位) | 逻辑运算<br>M=H                               | 算术运算<br>M=L,C <sub>n</sub> =H(无进位) |  |
| LLLL                                                                | Ā                                         | A减1                                 | Ā                                         | A                                  |  |
| LLLH                                                                | AB                                        | AB减1                                | $\overline{\mathbf{A}+\mathbf{B}}$        | A+B                                |  |
| LLHL                                                                | $\overline{\mathbf{A}} + \mathbf{B}$      | AB减1                                | AB                                        | $A + \overline{B}$                 |  |
| LLHH                                                                | 逻辑1                                       | 减1                                  | 逻辑0                                       | 减1 (即1111)                         |  |
| LHLL                                                                | $\overline{A+B}$                          | A加(A+B)                             | ĀB                                        | A加AB                               |  |
| LHLH                                                                | B                                         | AB加(A+B)                            | B                                         | (A+B)加AB                           |  |
| LHHL                                                                | $\overline{\mathbf{A} \oplus \mathbf{B}}$ | A减B减1                               | A $\oplus$ B                              | A减B减1 (即A加 <mark>B</mark> )        |  |
| LHHH                                                                | $A + \overline{B}$                        | $A + \overline{B}$                  | $\overline{AB}$                           | AB减1                               |  |
| HLLL                                                                | AB                                        | A加(A+B)                             | $\overline{\mathbf{A}} + \mathbf{B}$      | A加AB                               |  |
| HLLH                                                                | $\mathbf{A} \oplus \mathbf{B}$            | A加B                                 | $\overline{\mathbf{A} \oplus \mathbf{B}}$ | A加B                                |  |
| HLHL                                                                | В                                         | AB加(A+B)                            | В                                         | (A+B)加AB                           |  |
| HLHH                                                                | A+B                                       | A+B                                 | AB                                        | AB减1                               |  |
| HHLL                                                                | 逻辑0                                       | <b>A</b> 加 <b>A</b> *               | 逻辑1                                       | <b>A</b> 加 <b>A</b> *              |  |
| HHLH                                                                | AB                                        | AB加A                                | $A + \overline{B}$                        | (A+B)加A                            |  |
| HHHL                                                                | AB                                        | AB加A                                | A+B                                       | (A+B)加A                            |  |
| нннн                                                                | A                                         | A                                   | A                                         | A减1                                |  |

- 注意区分:
  - 十 加 田
- 三个符号分别表示的含义

# TD-CMX实验系统



实验系统电路示意图

# 运算器逻辑功能表

| 运算类型                  | S3 S2 S1 S0 | CN | 功能                            |
|-----------------------|-------------|----|-------------------------------|
|                       | 0000        | X  | F=A(直通)                       |
|                       | 0001        | X  | F=B (直通)                      |
| 逻辑运算                  | 0010        | X  | F=AB (FZ)                     |
|                       | 0011        | X  | F=A+B (FZ)                    |
|                       | 0100        | X  | F=/A (FZ)                     |
|                       | 0101        | X  | F=A 不带进位循环右移 B (取低 3 位)位 (FZ) |
|                       | 0110        | 0  | F=A 逻辑右移一位 (FZ)               |
| 移位运算                  |             | 1  | F=A 带进位循环右移一位 (FC, FZ)        |
|                       | 0111        | 0  | F=A 逻辑左移一位 (FZ)               |
|                       |             | 1  | F=A 带进位循环左移一位 (FC, FZ)        |
|                       | 1000        | X  | 置 FC=CN (FC)                  |
|                       | 1001        | X  | F=A 加 B (FC, FZ)              |
|                       | 1010        | X  | F=A 加 B 加 FC (FC, FZ)         |
| <b>算</b> 录 云 <b>9</b> | 1011        | X  | F=A 减 B (FC, FZ)              |
| 算术运算                  | 1100        | X  | F=A 减 1 (FC, FZ)              |
|                       | 1101        | X  | F=A 加 1 (FC, FZ)              |
|                       | 1110        | X  | (保留)                          |
|                       | 1111        | X  | (保留)                          |

表中"X"为任意态

## 两级先行进位ALU

74182是一个先行进位形成电路,和74181的进位产生输出G和进位传递输出P配合使用,可以实现两级先行进位。

设4片74181的先行进位输出依次为 $P_0$ , $G_0$ , $P_1$ , $G_1$ , $P_2$ , $G_2$ , $P_3$ , $G_3$ ,74182所提供的进位逻辑关系为:

$$\begin{split} & C_{n+x} = G_0 + P_0 C_n \\ & C_{n+y} = G_1 + P_1 C_{n+x} = G_1 + P_1 G_0 + P_1 P_0 C_n \\ & C_{n+z} = G_2 + P_2 C_{n+y} = G_2 + P_2 G_1 + P_2 P_1 G_0 + P_2 P_1 P_0 C_n \end{split}$$

此外,74182还提供组进位产生输出G\*和组进位传递输出P\*,用于实现三级 先行进位:

$$\begin{split} \textbf{P}^* &= \textbf{P}_3 \textbf{P}_2 \textbf{P}_1 \textbf{P}_0 \\ \textbf{G}^* &= \textbf{G}_3 + \textbf{P}_3 \textbf{G}_2 + \textbf{P}_3 \textbf{P}_2 \textbf{G}_1 + \textbf{P}_3 \textbf{P}_2 \textbf{P}_1 \textbf{G}_0 \\ \textbf{G}^* &+ \textbf{P}^* \textbf{C}_n = \textbf{G}_3 + \textbf{P}_3 \textbf{G}_2 + \textbf{P}_3 \textbf{P}_2 \textbf{G}_1 + \textbf{P}_3 \textbf{P}_2 \textbf{P}_1 \textbf{G}_0 + \textbf{P}_3 \textbf{P}_2 \textbf{P}_1 \textbf{P}_0 \textbf{C}_n \\ &= \textbf{G}_3 + \textbf{P}_3 \textbf{C}_{n+z} \end{split}$$



上图利用八片74181和两片74182构成两级先行进位的32位ALU。一片74182产生C<sub>4</sub>、C<sub>8</sub>、C<sub>12</sub>,另一片74182产生C<sub>20</sub>、C<sub>24</sub>、C<sub>28</sub>。

# 内部总线

根据总线所在位置,总线分为内部总线和外部总线两类。内部总线是指CPU内各部件的连线,而外部总线是指系统总线,即CPU与存储器、I/O系统之间的连线。本节讨论内部总线。

按总线的逻辑结构来说,总线可分为单向传送总线和双向传送总线。 所谓单向总线,就是信息只能向一个方向传送。所谓双向总线,就是信息可以分两个方向传送,既可以发送数据,也可以接收数据。



左图是带有缓冲器的4位双向数据总线,其中所用的基本电路就是三态门。当"发送"信号有效时,数据从左向右传送;当"接收"信号有效时,数据从右向左传送。



左图是带有锁存器的4位双 向数据总线,由DE触发器(带 有允许端E的D触发器)和三态 门组成。E=1时,总线上的数 据被接收到锁存器,此时发送信 号无效将三态门禁止; E=0时 ,触发器的锁存功能无效,发送 信号有效时将触发器输出端Q的 值送到数据总线上。

# 定点运算器的基本结构

运算器包括ALU、乘除法阵列、寄存器、多路开关、三态缓冲器、数据总线等逻辑部件。运算器的设计,主要围绕ALU、寄存器和数据总线之间之间如何传送操作数和运算结果进行。运算器大体有以下三种结构:

#### 1.单总线结构的运算器



在同一时间内,只能有一个操作数放在单总线上。为了把两个操作数输入到ALU,需要分两次来做,而且还需要A、B两个缓冲寄存器。这种结构的主要缺点是操作速度较慢,但控制电路简单。

#### 2.双总线结构的运算器



两个操作数可以分别通过总线1和总线2同时送到ALU去进行运算,并且立即可以得到运算的结果。但是ALU的输出不能直接送到总线上去,这是因为此时两条总线都被操作数所占据着,所以必须在ALU的输出端设置一个缓冲器,先将运算结果送入缓冲器,第二步再把结果送至目的寄存器。显然,它的执行速度比单总线要快,每次操作比单总线少一步。

#### 3.三总线结构的运算器



ALU的两个输入端分别由两条总线供给,输出与第三条总线相连,这样算术逻辑操作可以在一步控制之内完成。如果某一个数不需要运算和修改,而需要直接由总线2传到总线3,可通过总线旁路器把数据送出,而不必借助于ALU。三总线结构的特点是操作速度快,但控制较前两种复杂。

作业:

写出 74181ALU

S3~S0:0011

S3~S0:1001

两种状态下的正逻辑的输出结果(含推导过程)

## 浮点加减运算

设有两个浮点数x和y,它们分别为

$$x=2^{Ex}\cdot M_x$$
  $y=2^{Ey}\cdot M_y$ 

其中 $E_x$ 和 $E_y$ 分别为数x和y的阶码, $M_x$ 和 $M_y$ 为数x和y的尾数。

两浮点数进行加法和减法的运算规则是:

$$x \pm y = \begin{cases} (M_x \cdot 2^{Ex-Ey} \pm M_y) \cdot 2^{Ey} & E_x \le E_y \\ (M_x \pm M_y \cdot 2^{Ey-Ex}) \cdot 2^{Ex} & E_x > E_y \end{cases}$$



以十进制为例,思考,如何计算

 $7.5\times10^5 + 8.25\times10^7$ 

#### (1) 0操作数检查

如果判知两个操作数x或y中有一个数为0,即可得知运算结果而没有必要再进行后续的一系列操作以节省运算时间。

#### (2) 比较阶码大小并完成对阶

若二数阶码相同,表示小数点是对齐的, 可以进行尾数的加减运算: 若二数阶码不同, 表示小数点位置没有对齐, 此时必须使二数阶 码相同,这个过程叫作对阶。由于浮点数是规 格化的, 尾数左移会引起最高有效位的丢失, 造成很大误差:尾数右移虽引起最低有效位的 丢失,但造成误差较小。因此,对阶操作规定 使尾数右移,阶码相应增加。对阶时,总是使 小阶向大阶看齐,即小阶的尾数向右移位,每 右移一位,其阶码加1,直到两数阶码相等。 按"小阶向大阶看齐"的原则。



#### (3) 尾数求和

对阶结束后,即可进行尾数的求和运算。其方法与定点加减法运算一样。

#### (4) 结果规格化

尾数加减运算后得到的结果可能不是规格化数,此时要对结果进行规格化,具体做法取决于浮点数格式。设尾数M用补码表示,规格化的要求是 $\frac{1}{2} \le M < 1$ 或 $-1 \le M < -\frac{1}{2}$ 。假定运算中采用双符号位,运算结果可能有6种情况:

- ①  $00.1 \times \times \cdots \times$
- ② 11.0 ×× ···×
- $\bigcirc$  00.0  $\times \times \cdots \times$
- (4) 11.1 ×× ··· ×
- $\bigcirc$  01.××× ··· ×
- $\bigcirc$  10.××× ··· ×

第①种和第②种已经是规格化数。

第③种和第④种需要使尾数左移以实现规格化,称为左规。尾数每左移一次,阶码相应减1。左规可以进行多次。

第⑤种和第⑥种表示运算结果的绝对值大于1,在定点运算中称为溢出,但对浮点数可以通过尾数右移实现规格化,称为右规。尾数每右移一位,阶码相应加1。右规只需进行一次。

#### (5) 舍入处理

对阶或右规时,尾数要向右移位,被右移的尾数的低位部分会被丢掉,此时要进行舍入处理。简单的舍入方法有两种:一种是"0舍1入"法,即被丢掉数位的最高位为0则舍去,为1则将尾数的末位加1。另一种是"恒置1"法(又称冯·诺依曼舍入),即只要有数位被移掉,就将尾数的末位置1。P63

IEEE 754标准中,舍入处理提供了四种可选方法:

就近舍入:其实质就是"四舍五入"。例如,尾数超出规定的23位的多余数字是10010,则最低有效位应加1;若多余的5位是01111,则简单的截尾。对多余的5位是10000这种特殊情况,规定若最低有效位现为0,则截尾;若最低有效位现为1,则向上进一位使其变为0。

朝0舍入:朝数轴原点方向舍入,就是简单的截尾。无论尾数是正数还是负数,截尾都使结果的绝对值比原值的绝对值小。

**朝**+∞**舍入**:对正数来说,只要多余位不全为**0**则向最低有效位进**1**;对负数来说则是简单的截尾。舍入后的值一定比原值大。

尾数用补码表示时,其舍入的效果应当和用原码表示时的舍入效果完全相同。如果尾数用原码表示时采用的是"0舍1入"法,则尾数用补码表示且尾数为负数时其舍入规则为:

- ① 被丢掉的各位均为0时,舍去;
- ② 被丢掉数位的最高位为0,以下各位不全为0,则舍去;
- ③ 被丢掉数位的最高位为1,且以下各位全为0,则舍去;
- ④ 被丢掉数位的最高位为1,以下各位不全为0,则将尾数的末位加1。

#### (6) 溢出处理



机器浮点数值大于最大正数A值,或小于最小负数B值时,称为上溢,这两种情况意味着阶码运算值超出了它所表示的范围,机器必须做中断处理。

当机器浮点数值小于最小正数a值,或大于最大负数b值时,称为下溢。下溢通常看作为机器零。

浮点数的溢出是以其阶码溢出表现出来的。若阶码溢出,则要进行相应处理。另外对尾数的溢出也需要处理。

**阶码上溢:** 正指数值超过了阶码可能表示的最大值,一般将其认为是 $+\infty$ 和 $-\infty$ 。

阶码下溢:负指数值超过了阶码可能表示的最小值,一般将其认为是0。

尾数上溢:两个同符号尾数相加,结果的绝对值超过1,需进行右规。

114尾数下溢:尾数的有效位从右端移出了,需进行舍入处理。

```
[例] 设 x = 2<sup>2</sup>×0.11011011
           y = 2^4 \times (-0.10101100), 求 x + y
    [x]浮=00 010. 0.11011011
    [y]浮=00 100, 1.01010100
  <1>0 操作数检查
  <2> 求阶差并对阶
     \triangle E = E \times - E y = [E \times] + [-E \times] = 000010 + 11100 = 111100
     即\triangle E为-2, x的阶码小,应使Mx右移两位,Ex加2,
     [x]浮=00 100,0.00110110(11)
     其中(11)表示Mx右移2位后移出的最低两位数。舍入处理
     [x]浮=00 100,0.00110111
  <3>尾数求和(注意,需要用双符号位来判断溢出)
     00.00110111
  + 11.01010100
     11.10001011 符号位为11.不溢出
  <4>规格化处理
     尾数运算结果的符号位与最高数值位同值,应执行左规处理,结果为
    1.00010110,阶码为 00 011
  <5>舍入处理
  <6>阶码判溢出: 阶码符号位为00,不溢出
120 x + y = 2^{011} \times (-0.11101010)
```

例:已知 $x = -0.875 \times 2^1$ , $y = 0.625 \times 2^2$ ,设阶码2位,阶符1位,数符1位,尾数3位。通过补码运算规则求z = x - y的二进制浮点规格化的结果。

S1 =(-0.111)<sub>2</sub> [S1]
$$\stackrel{?}{\Rightarrow}$$
=1.001  
S2 =(+0.101)<sub>2</sub> [S2] $\stackrel{?}{\Rightarrow}$ =0.101 [-S2] $\stackrel{?}{\Rightarrow}$ =1.011

0 操作数检查

对阶后:

x 010,1100

-y 010,1011

尾数1.001右移一位,阶码加1 1.1001,尾数4位, 进行舍入,舍入后为 1.100

尾数(采用双符号位):

11.100

+ 11.011

110.111 符号位为10,溢出 小数点左移,阶码加1

阶码为3

尾数1.011 -0.625×2<sup>3</sup>

<sub>-24</sub>结果:011,1011

例:已知 $x = 0.125 \times 2^1$ , $y = 0.625 \times 2^3$  ,设阶码2位,阶符1位,数符1位,尾数3位。通过补码运算规则求z = x - y的二进制浮点规格化的结果。

0 操作数检查

对阶后:

x 011,0000

-y 011,1011

尾数为零:

z = -y

结果:

011, 1011

避免将一个很大的数与很小的数相加减,

小数会被大数"吃掉"

# 浮点乘除运算

设有两个浮点数x和y:

$$x=2^{Ex}\cdot M_x$$
  
 $y=2^{Ey}\cdot M_y$ 

浮点乘法运算的规则是:

$$x \times y = 2^{(Ex+Ey)} \cdot (M_x \times M_y)$$

$$x \div y = 2^{(Ex-Ey)} \cdot (M_x \div M_y)$$

即商的尾数是两数的尾数之商,商的阶码是两数的阶码之差。

浮点乘除运算可分为六步: **0**操作数检查; 阶码加/减操作; 尾数乘/除操作; 结果规格化和舍入处理,确定积的符号。

#### (1) 阶码运算

浮点数的阶码通常用补码或移码表示。

下面介绍移码的运算规则[补充内容]。

移码的定义为

$$[x]_{8}=2^{n}+x$$
  $2^{n}>x\geq -2^{n}$ 

按此定义,则有

$$[x]_{8}+[y]_{8}=2^{n}+x+2^{n}+y=2^{n}+(2^{n}+(x+y))$$
  
=2<sup>n</sup>+[x+y]<sub>8</sub>

即直接用移码对阶码求和时,结果的最高位多加了个1。要得到正确的移码结果,必须对结果的符号位再执行一次求反。

求阶码之和可以采用另一种方式实现。[y]\*的定义为:

$$[y]_{\dot{\uparrow}} = 2^{n+1} + y$$
 (mod  $2^{n+1}$ )  
于是  $[x]_{\dot{\delta}} + [y]_{\dot{\uparrow}} = 2^n + x + 2^{n+1} + y = 2^{n+1} + (2^n + (x+y))$   
 $= [x+y]_{\dot{\delta}}$  (mod  $2^{n+1}$ )

同理:

$$[x-y]_{8} = [x]_{8} + [-y]_{4} \pmod{2^{n+1}}$$

若阶码的运算结果溢出,上述公式不成立。为进行溢出检测,运算中采用双符号位,并规定移码的高符号位为0,则结果的高符号位为1表示溢出。结果的符号位为10表示上溢,为11表示下溢,01表示正,00表示负。

#### (2) 尾数处理

浮点加减法对结果的规格化和舍入处理也适用于浮点乘除法。

尾数用原码表示时,简单的舍入方法有两种:一种是"恒置1"法,即只要有数位被移掉,就将尾数的末位置1。另一种是"0舍1入"法,即如果右移时被丢掉数位的最高位为0则舍去,为1则将尾数的末位加1。

尾数用补码表示时,其舍入的效果应当和用原码表示时的舍入效果完全相同。如果尾数用原码表示时采用的是"0舍1入"法,则尾数用补码表示且 尾数为负数时其舍入规则为:

- ① 被丢掉的各位均为0时, 舍去;
- ② 被丢掉数位的最高位为0,以下各位不全为0,则舍去;
- ③ 被丢掉数位的最高位为1,且以下各位全为0,则舍去;
- ④ 被丢掉数位的最高位为1,以下各位不全为0,则将尾数的末位加1。

[例26] x = +011, y = +110, 求[x + y]<sub>8</sub> 和 [x - y]<sub>8</sub>,并 判断是否溢出。

[解:]

$$[x]$$
移=01 011,  $[y]$ 补=00 110,  $[-y]$ 补=11 010

$$[x+y]$$
移= $[x]$ 移+ $[y]$ 补=10 001, 结果上溢。  $[x-y]$ 移= $[x]$ 移+ $[-y]$ 补=00 101, 结果正确,为-3。

[例] x = -011, y = +110, 求[x + y]<sub>移</sub> 和 [x - y]<sub>移</sub>, 并判断是否溢出。

## [解:]

[x]移=00 101, [y]补=00 110, [-y]补=11 010

$$[x+y]$$
移= $[x]$ 移+ $[y]$ 补=01 011, 结果+3。  $[x-y]$ 移= $[x]$ 移+ $[-y]$ 补=11 111, 结果下溢

[例27] 设[
$$x$$
1]补=11.01100000, [ $x$ 2]补=11.01100001, [ $x$ 3]补=11.01101000, [ $x$ 4]补=11.01111001, 求执行只保留小数点后4位有效数字的舍入操作值。[解:]

执行舍入操作后,其结果值分别为

【例30】设有浮点数  $x=2^{-5}\times0.0110011$ ,  $y=2^{3}\times(-0.1110010)$ ,阶码用4位补码表示,尾数 (含符号位) 用8位原码表示。求[ $x\times y$ ]浮。要求用原码完成尾数乘法运算,运算结果尾数保留高8位(含符号位),并用尾数低位字长值处理舍入操作。

移码采用双符号位,尾数补码采用单符号位,则有

[Mx]原=0.0110011, [My]原=1.1110010,

[Ex]  $\stackrel{*}{=}$  11 011, [Ey]  $\stackrel{*}{=}$  00 011,

[x]浮=11 011, 0.0110011, [y]浮=00 011, 1. 1110010

- 1) 求阶码和
  - [Ex+Ey]补=[Ex]补+[Ey]补=11 011+00 011=11 110,值为补码形式-2。
- 2) 尾数乘法运算可采用原码阵列乘法器实现,即有 [Mx]原 $\times [My]$ 原=[0.0110011]原 $\times [1.1110010]$ 原=[1.0101101,0110110]原

## [1.0101101,0110110]原

(3) 规格化处理 乘积的尾数符号位为最高数值位符号相同,不是规格化的数,需要左规,阶码变为11 101(-3), 尾数变为 1.1011010,1101100。

(4) 舍入处理 尾数为负数,取尾数高位字长,按舍入规则,舍去 低位字长,故尾数为1.1011011。 最终相乘结果为

 $[x \times y]$ 浮=11 101,1.1011011

其真值为

 $x \times y = 2^{-3} \times (-0.1011011)$ 

# 浮点运算流水线

把执行一条指令称为一个任务,一个任务可以分割为一系列子任务。 每个子任务的处理过程称为过程段。不同任务的子任务可以在流水线的各 个过程段并发执行,从而实现子任务级的并行。

流水线中,原则上要求各个过程段的处理时间相同。设任务*T*被分成*k* 个子任务,可表达为

$$T = \{ T_1, T_2, \dots, T_k \}$$



设过程段  $S_i$ 所需的时间为 $\tau_i$ ,缓冲器的延时为 $\tau_l$ ,线性流水线的时钟周期定义为

$$\tau = \max\{\tau_i\} + \tau_l = \tau_m + \tau_l$$

流水线处理的频率为 $f=1/\tau$ 。从理论上说,一个具有k 级过程段的流水线处理 n 个任务需要的时钟周期数为

$$T_k = k + (n-1)$$

如果用非流水线的硬件来处理这n个任务,时间上只能串行进行,则所需时钟周期数为

$$T_L = n \cdot k$$



将 $T_L$ 和 $T_k$ 的比值定义为k级线性流水线的加速比:

$$C_k = \frac{T_L}{T_k} = \frac{n \cdot k}{k + (n-1)}$$

当n >> k时, $C_k \to k$ 。这就是说,理论上k级线性流水线处理几乎可以提高k倍速度。但实际上这个理想的加速比不一定能达到。

右图是3段浮点加法器的框图。 设两个IEEE 754标准的规格化浮点数 为:

X=1.1000×2²Y=1.1100×2⁴缓冲器中保存的流水运算结果如图。





向量加法计算的流水时空图

- 关于规格化的两种形式
  - 1、IEEE754的要求为1.M的形式
  - 2、设尾数M用补码表示,规格化的要求是  $\frac{1}{2} \leq M < 1$ 或 $-1 \leq M < -\frac{1}{2}$
- 关于移码的两种形式
  - 1、IEEE754的要求为e+127的形式
  - 2、其余的为2n+x

若不指明为IEEE754标准,所指的规格化、移码均为第2种

# 本节要点

- 1、浮点数加、减运算过程
- 2、浮点数乘、除运算过程

# 作业

1、分析在正逻辑的情况下,当

**S3S2S1S0**=LHLH, M=H, M = L时, **74181**实现 何种运算?给出具体推导过程

- 2, P64 9
- 3、X=2+010×(+0.1101), Y=2+100×(-0.1010), 按照浮点数加减法的计算方法求X-Y

## 练习:

P648(2) 用加减交替法来实现

知识点: 原码阵列除法

习题8 (2) 
$$[|x|]_{\stackrel{}{\mathbb{N}}}=0.01011$$
  $[|y|]_{\stackrel{}{\mathbb{N}}}=0.11001$   $[-|y|]_{\stackrel{}{\mathbb{N}}}=1.00111$ 

## 第二章 复习

- 数的原码、补码、反码、移码的表示方法,注意边界情况 (0的表示,表示范围,-2<sup>n</sup>)
- 浮点数的表示方法: 尾数用定点小数的原码或补码表示; 指数用整数的补码或移码表示。数符、阶符分别表示什么 含义?正、负、绝对值大于1 规格化最小正数是: 1,00...0 0.10...0
- 数的规格化表示方法
- IEEE754表示方法 尾数用原码表示,规格化为1.M的形式,表示时隐藏1;阶码为真值加127
- 指定格式的浮点数表示方法
- 补码加法的公式,补码减法的公式
- 溢出的检测,单符号位,双符号位
- 全加器的公式以及时间延迟
- 行波进位补码加/减法器的电路分析
- 原码阵列乘法器

### 第二章 复习

- 对2求补电路
- 间接补码阵列乘法器
- 直接补码阵列乘法器
- 原码除法的两种方法:恢复余数法,加减交替法
- 阵列除法器
- · ALU的电路基本概念
- 先行进位的基本原理
- 浮点加减运算
- 浮点乘除运算
- 流水线的基本概念以及优点

作业:

P61

8(1) 用加减交替法来实现